MSB: Most Significant Bit ------- 最高有效位
LSB: Least Significant Bit ------- 最低有效位
网络字节序是big-endian, 因为网络很大
Intel x86 全部 Little endian <-----x86系统是小端字节序系统
MIPS NT Little endian
MIPS UNIX Big endian
IXP1200 ARM核心 全部 Little endian
Motorola680x 全部 Big endian
big-endian: MSB存放在最低端的地址上
little-endian:LSB存放在最低端的地址上
举例,双字节数0x1234以little-endian的方式存在起始地址0x00002000中:
| data |<-- address
| 0x34 |<-- 0x00002000
| 0x12 |<-- 0x00002001
采用大端方式进行数据存放符合人类的正常思维,而采用小端方式进行数据存放利于计算机处理。
如果将一个32位的整数0x12345678存放到一个整型变量(int)中,这个整型变量采用大端或者小端模式在内存中的存储由下表所示。
为简单起见,本书使用OP0表示一个32位数据的最高字节MSB(Most Significant Byte),使用OP3表示一个32位数据最低字节LSB(Least Significant Byte)。
---------------------------
地址偏移 大端模式 小端模式
0x00 12(OP0) 78(OP3)
0x01 34(OP1) 56(OP2)
0x02 56(OP2) 34(OP1)
0x03 78(OP3) 12(OP0)
---------------------------
如果将一个16位的整数0x1234存放到一个短整型变量(short)中。这个短整型变量在内存中的存储在大小端模式由下表所示。
---------------------------------
地址偏移 大端模式 小端模式
0x00 12(OP0) 34(OP1)
0x01 34(OP1) 12(OP0)
-------------------------------------
// 联合体uniON的存放顺序是所有成员都从低地址开始存放
union
{
unsigned int a;
unsigned char b;
}c;
c.a = 1;
printf("%d %d %d\n", &c, &c.a, &c.b);
if(c.b == 1) {
printf("small \n");
} else {
printf("big \n");
}
int aa = 1;
char *p = (char*)&aa;
printf("%d %d\n", p, p+1);
if(*p == 1) {
printf("small \n");
} else {
printf("big \n");
}
LSB: Least Significant Bit ------- 最低有效位
网络字节序是big-endian, 因为网络很大
Intel x86 全部 Little endian <-----x86系统是小端字节序系统
MIPS NT Little endian
MIPS UNIX Big endian
IXP1200 ARM核心 全部 Little endian
Motorola680x 全部 Big endian
big-endian: MSB存放在最低端的地址上
little-endian:LSB存放在最低端的地址上
举例,双字节数0x1234以little-endian的方式存在起始地址0x00002000中:
| data |<-- address
| 0x34 |<-- 0x00002000
| 0x12 |<-- 0x00002001
采用大端方式进行数据存放符合人类的正常思维,而采用小端方式进行数据存放利于计算机处理。
如果将一个32位的整数0x12345678存放到一个整型变量(int)中,这个整型变量采用大端或者小端模式在内存中的存储由下表所示。
为简单起见,本书使用OP0表示一个32位数据的最高字节MSB(Most Significant Byte),使用OP3表示一个32位数据最低字节LSB(Least Significant Byte)。
---------------------------
地址偏移 大端模式 小端模式
0x00 12(OP0) 78(OP3)
0x01 34(OP1) 56(OP2)
0x02 56(OP2) 34(OP1)
0x03 78(OP3) 12(OP0)
---------------------------
如果将一个16位的整数0x1234存放到一个短整型变量(short)中。这个短整型变量在内存中的存储在大小端模式由下表所示。
---------------------------------
地址偏移 大端模式 小端模式
0x00 12(OP0) 34(OP1)
0x01 34(OP1) 12(OP0)
-------------------------------------
// 联合体uniON的存放顺序是所有成员都从低地址开始存放
union
{
unsigned int a;
unsigned char b;
}c;
c.a = 1;
printf("%d %d %d\n", &c, &c.a, &c.b);
if(c.b == 1) {
printf("small \n");
} else {
printf("big \n");
}
int aa = 1;
char *p = (char*)&aa;
printf("%d %d\n", p, p+1);
if(*p == 1) {
printf("small \n");
} else {
printf("big \n");
}