memcpy與大小端


搬運自我的CSDNhttps://blog.csdn.net/u013213111/article/details/100149145

參考:
大端 小端 與memcpy
網絡字節序和大小端字節序

來看這樣一段代碼:
本意是想把uint8_t a[2]中的內容合成一個uint16_t b

#include <stdlib.h>
#include <stdio.h>
#include <stdint.h>

int main()
{
	uint8_t a[2] = { 0x11, 0x22 };
	uint16_t b;
	memcpy(&b, a, sizeof(b));

	printf("a[0]:%x,a[1]:%x\n", a[0], a[1]);
	printf("b:%x\n", b);

	return 0;
}

在intel的電腦上跑出來的結果如何呢:

a[0]:11,a[1]:22
b:2211

也就是說,假如a[1]中存儲的是高位byte,a[0]中存儲的是低位byte,那么最終合成的uint16_t是正確的;而假如a[0]中存儲的是高位byte,a[1]中存儲的是低位byte,那么結果就是錯誤的了。
然而並不是所有的計算機系統都如此,而是要看系統是大端存儲模式還是小端存儲模式。
小端存儲模式(小端字節序),指的是數據的高字節位置保存在內存的高地址處,數據的低字節保存在內存的低地址處,例如intel x86采用的就是小端存儲模式。
相反地,大端存儲模式(大端字節序),指定就是把數據的高字節保存在內存的低地址中,數據的低字節保存在內存的高地址中。

當計算機之間通過網絡傳輸數據時,就特別需要注意大小端的問題。首先,不同的計算機系統可能並不都采用大端模式或者都采用小端模式,在混用存儲模式的情況下,就有可能導致數據讀取的錯誤;其次,由於網絡字節序被規定為大端字節序,而如果計算機采用的是小端字節序,那么就需要進行一次轉換了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM