1.大端模式,是指數據的低位保存在內存的高地址中,而數據的高位,保存在內存的低地址中;小端模式相反
2.為什麼有大小端之分???
因為在計算機系統中,存儲是以字節為單位的,每個地址單元都對應著一個字節,一個字節=8bit。在C語言中除了8bit的char之外,還有16bit的short型,32bit的long型(要看具體的編譯器)。對於位數大於8位的處理器,例如16位或者32位的處理器,由於寄存器寬度大於一個字節,如何安排多個字節的存儲,這就有了大端存儲模式和小端存儲模式
3.各自的優勢:
小端模式:強制轉換數據不需要調整字節內容,1、2、4字節的存儲方式一樣。
大端模式:符號位的判定固定為第一個字節,容易判斷正負。
4.常用的X86結構是小端模式,而KEIL C51則為大端模式。很多的ARM,DSP都為小端模式.
5.C語言判斷大小端模式
方法一:
代碼如下:
void IsBigEndian()
{
short int a = 0x1122;//十六進制,一個數值占4位
char b = *(char *)&a; //通過將short(2字節)強制類型轉換成char單字節,b指向a的起始字節(低字節)
if( b == 0x11)//低字節存的是數據的高字節數據
{
//是大端模式
}
else
{
//是小端模式
}
}
方法二:
代碼如下:
void IsBigEndian()//原理:聯合體union的存放順序是所有成員都從低地址開始存放,而且所有成員共享存儲空間
{
union temp
{
short int a;
char b;
}temp;
temp.a = 0x1234;
if( temp.b == 0x12 )//低字節存的是數據的高字節數據
{
//是大端模式
}
else
{
//是小端模式
}
}
在我的機子上驗證了一下是小端模式