计算机 Little-Endian 和 Big-Endian (大小字节序、大小端)

一、概念

endian:字节存储顺序,端模式。

Little-Endian 和 Big-Endian表示的是计算机字节顺序,所谓的字节顺序指的是长度跨越多个字节的数据的存放形式(若只有一个字节则不需考虑字节序的问题)对于整型、长整型等数据类型,Big endian 认为第一个字节是最高位字节(按照从低地址到高地址的顺序存放数据的高位字节到低位字节);而Little endian 则相反,它认为第一个字节是最低位字节(按照从低地址到高地址的顺序存放数据的低位字节到高位字节)。

大部分人在实际的开发中都很少会直接和字节序打交道。唯有在跨平台以及网络程序中字节序才是一个应该被考虑的问题。TCP/IP各层协议将字节序定义为Big-Endian,因此TCP/IP协议中使用的字节序通常称之为网络字节序。

二、举例

例如,假设从内存地址0x0000 开始有以下数据:0x12 0x34 0xab 0xcd。
如果我们去读取一个地址为0x0000的四个字节变量,若字节序为big-endian,则读出结果为0x1234abcd;若字节序位little-endian,则读出结果为 0xcdab3412。

如果我们将0x1234abcd 写入到以0x0000 开始的内存中,则Little endian 和Big endian 模式的存放结果如下:
地址               0x0000 0x0001 0x0002 0x0003
big-endian        0x12   0x34     0xab     0xcd
little-endian      0xcd   0xab     0x34     0x12
采用Little-Endian的 操作系统: FreeBSD,Linux,Windows x86的机器 ;

采Big-Endian的操作系统:MAC OS, ARM, Alpha,摩托罗拉的PowerPC, Network中的变量 ,Java语言.

三、判断大小端的方法

实例如下:环境为32位机

int i=1;

Big-endian方式下:   0x00            0x00             0x00             0x01

Little-endian方式下:0x01            0x00             0x00             0x00

地址:                      1000            1001            1002             1003

获取i的地址,为1000处   &i  

强制转换指针类型为char * ,即从地址起点截断1个字节       (char*)&i

此时

Big-endian方式下为:0x00

Little-endian方式下为:0x01

得出如下结论

int i=1;

若*(char*)&i等于1 则为Little-endian方式,否则为Big-endian方式。

我在自己笔记本上得出的结果是'\x1',应该是16进制的1吧。


你可能感兴趣的:(计算机,c++,硬件,计算机,字节序,大小端,big-endian,little-endian)