计算机大小端详解

来源:互联网 发布:黄焖鸡怎么做好吃 知乎 编辑:程序博客网 时间:2024/04/28 15:12

一、名词解释(百度百科)

大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理,地址由小向大增加,而数据从高位往低位放,这和我们的阅读习惯一致。
小端模式,是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低。
0x11223344的数据在大端小端中的存储方式,如下图:

例如:DWORD = 0x12345678;
大端:数据存储方式为:0x12 0x34 0x56 0x78 划分成每个字节,这种方式更适合我们阅读理解。
小端:数据存储方式为:0x78 0x56 0x34 0x112划分成每个字节,这种方式是目前大部分计算机(X86)所用的存储方式。

二、判断计算机大小端

1、使用联合

union un{int i;char ch[2];};int main(int argc, char* argv[]){un u;u.ch[0] = 2;u.ch[1] = 1;if(u.i == 0x0102){printf("is Big_Endian\n");}elseprintf("is Little_Endian\n");        return 0;}
输出结果:is Little_Endian


2、强制转换

bool isBig_Endian(){unsigned short value = 0x1234;if(*((unsigned char*)&value) == 0x12)return true;elsereturn false;}int main(int argc, char* argv[]){if(isBig_Endian())cout<<"is Big_Endian"<<endl;elsecout<<"is Little_Endian"<<endl;         return 0;}
输出结果:is Little_Endian


0 0