一、概述
字节序用来表示数据在内存中的排布方式,它分为两种:高字节序和低字节序,也被称为大小字节序。因为内存是从低到高布局,所以如果内存的低位存的是数据的低位,该字节序被称为低字节序。而如果内存的低位存的数据高位,该字节序被称为高字节序。
例如一个 32 位 int 类型变量 n=0x12345678(逻辑中 0x78 是低位,0x12 是高位),把它放在内存 0x01-0x04 上,则它以低字节序和高字节序存储的形式为:

通常,计算机中的的存储方式是低字节序,网络传输的字节序是高字节序。
可以通过以下代码来判断当前环境的字节序:
|
1 2 3 4 5 6 7 8 9 10 11 12 |
#include <stdio.h> int main() { int n = 0x12345678, i = 0; const char *p = (void *)&n; while (i++ < 4) { printf("%p: 0x%x\n", p, *p); p++; } return 0; } |
结果 0x78 在低位,是低字节序:
|
1 2 3 4 |
0x7ffdd6dd7e8c: 0x78 0x7ffdd6dd7e8d: 0x56 0x7ffdd6dd7e8e: 0x34 0x7ffdd6dd7e8f: 0x12 |
二、相关面试题
2.1 下面程序的结果是多少
|
1 2 3 4 5 6 |
int main()) { unsigned int a = 0xfffffff7; unsigned char ch = (unsigned char)a; char* b = (char*)&ch; printf("%08x %08x\n", ch, *b); } |
int 在内存中占四个字节,char 占一个字节,所以 int->char 数据会被截断,ch 只会取到 a 的第一个字节。而计算机中内存的分布方式是低字节序,所以 ch 的值是 0xf7 。
在 printf 中,对于无符号类型的数据,如果数据宽度不够,不够的位补会 0,有符号的补 f 。所以 ch 输出 0x000000f7,*b 输出 0xfffffff7 。
2.2 求下面代码输出
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
#include <stdio.h> typedef union X { int x; char y[4]; }X; int main() { X a; a.x = 0x11223344; printf("0x%x 0x%x 0x%x 0x%x\n", a.y[0], a.y[1], a.y[2], a.y[3]); return 0; } |
计算机的字节序是低字节序,所以 a.x 在内存中的分布依次是 0x11, 0x22, 0x33, 0x44,程序的输出为:0x44 0x33 0x22 0x11 。







评论