所謂的大端模式,是指資料的低位儲存在記憶體的高位址中,而資料的高位,儲存在記憶體的低位址中;
網路傳輸是大端儲存模式
所謂的小端模式,是指資料的低位儲存在記憶體的低位址中,而資料的高位儲存在記憶體的高位址中。
為什麼會有大小端模式之分呢?這是因為在計算機系統中,我們是以位元組為單位的,每個位址單元都對應著乙個位元組,乙個位元組為8bit。但是在c語言中除了8bit的char之外,還有16bit的short型,32bit的long型(要看具體的編譯器),另外,對於位數大於8位的處理器,例如16位或者32位的處理器,由於暫存器寬度大於乙個位元組,那麼必然存在著乙個如果將多個位元組安排的問題。因此就導致了大端儲存模式和小端儲存模式。例如乙個16bit的short型x,在記憶體中的位址為0x0010,x的值為0x1122,那麼0x11為高位元組,0x22為低位元組。對於大端模式,就將0x11放在低位址中,即0x0010中,0x22放在高位址中,即0x0011中。小端模式,剛好相反。我們常用的x86結構是小端模式,而keil c51則為大端模式。很多的arm,dsp都為小端模式。有些arm處理器還可以由硬體來選擇是大端模式還是小端模式。
記憶體位址
0x4000
0x4001
存放內容
0x34
0x12
而在big-endian模式cpu記憶體中的存放方式則為:
記憶體位址
0x4000
0x4001
存放內容
0x12
0x34
32bit寬的數0x12345678在little-endian模式cpu記憶體中的存放方式(假設從位址0x4000開始存放)為:
記憶體位址
0x4000
0x4001
0x4002
0x4003
存放內容
0x78
0x56
0x34
0x12
而在big-endian模式cpu記憶體中的存放方式則為:
記憶體位址
0x4000
0x4001
0x4002
0x4003
存放內容
0x12
0x34
0x56
0x78
13、在32位little endian機器上執行該程式,得到結果是什麼?
#include inta.1 2 3main()
b 1 0 2
c ......
d 3 2 1
解析:因為long long 是8個位元組的,%d是4個位元組的,溢位覆蓋了後面,然後又是小端規則的。
int a = 0x12345678;【傳入引數,由右往左,棧空間記憶體從高往低,little endian, 棧空間如下:---------------------------------->
78 56 34 12 (little endian)
12 34 56 78 (big endian)
記憶體高位->【棧底】
在小端序的機器中,如果 1
2
3
4
union
x;
如果:x a;
a.x=0x11223344;//16 進製 則:______
a.y[3]=0x11
01 大端小端
計算機儲存資料是按大端或者小端將資料儲存在記憶體上.一般處理器都只選擇其中的一種,通常intel和amd處理器都是採用小端儲存方式,也有一些處理器是採用大端方式,如果ibm公司的處理器.小端儲存 0x1003 0x78 0x1002 0x56 0x1001 0x34 0x1000 0x12 大端儲存...
002 大端和小端的區別
一 大小端出現原因 計算機系統是以位元組為單位的,每個位址單元都對應著乙個位元組,乙個位元組為8bit。但對於位數大於8位的處理器,如16位或32位 64位的處理器,由於暫存器寬度大於乙個位元組,那麼必然存在乙個如何將多個位元組安排的問題。因此就導致了大端儲存模式和小端儲存模式的出現。二 為什麼會有...
大端和小端
1 小端與大端 對於乙個由2個位元組組成的16位整數,在記憶體中儲存這兩個位元組有兩種方法 一種是將低序位元組儲存在起始位址,這稱為小端 little endian 位元組序 另一種方法是將高序位元組儲存在起始位址,這稱為大端 big endian 位元組序。2 下面是兩個具體例子 記憶體位址 小端...