大端模式
所謂的大端模式,是指資料的高位,儲存在記憶體的低地址中,而資料的低位,儲存在記憶體的高地址中,這樣的儲存模式有點兒類似於把資料當作字串順序處理:地址由小向大增加,而資料從高位往低位放;
例子: 0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000 0000440: b484 6c4e 004e ed00 0000 0000 0100 0000 在大端模式下,前16位應該這樣讀: e684
記憶方法:
地址的增長順序與值的增長順序相反
小端模式
所謂的小端模式,是指資料的高位儲存在記憶體的高地址中,而數 據的低位儲存在記憶體的低地址中,這種儲存模式將地址的高低和資料位元權有效地結合起來,高地址部分權值高,低地址部分權值低,和我們的邏輯方法一致。
例子: 0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000 0000440: b484 6c4e 004e ed00 0000 0000 0100 0000 在小端模式下,前16位應該這樣讀: 84e6
記憶方法:
地址的增長順序與值的增長順序相同
為什麼有大小端模式之分
為什麼會有大小端模式之分呢?這是因為在電腦系統中,我們是以位元組為單位的,每個地址單元都對應著一個位元組,一個位元組為 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處理器還可以由硬體來選擇是大端模式還是小端模式。
測試編輯器屬哪種模式
下面這段代碼可以用來測試一下你的編譯器是大端模式還是小端模式:
short int x;
char x0,x1;
x=0x1122;
x0=((char*)&x)[0]; //低地址單元
x1=((char*)&x)[1]; //高地址單元 若x0=0x11,則是大端; 若x0=0x22,則是小端......
上面的程式還可以看出,資料定址時,用的是低位位元組的地址。
linux作業系統中對大小端的判斷:
static union
{
char c[4];
unsigned long l;
} endian_test = { { 'l', '?', '?', 'b' } };
#define ENDIANNESS ((char)endian_test.l)
(如果ENDIANNESS=’l’表示系統為little endian,為’b’表示big endian )。
使用C語言判斷處理器的大小端
[1]int checkCPU()
{
union w
{
int a;
char b;
} c;
c.a = 1;
return (c.b == 1); /* 1 : little-endian */ /* 0 : big-endian */
}
#include<stdio.h>
int main(void)
{
int a = 0x12345678;
unsigned char *p =
(unsigned char *)&a;
if (0x78 == *p)
{
printf("littleend\n");
}
else
{
printf("bigend\n");
}
return 0;
}