字节顺序,又称端序,尾序(英语:Endianness)。在计算机科学领域中,是跨越多字节的程序对象的存储规则。
在几乎所有的机器上,多字节对象都被存储为连续的字节序列。例如在C语言中,一个类型为int的变量x地址为0x100,那么其对应地址表达式&x的值为0x100。且x的四个字节将被存储在存储器的0x100,0x101,0x102,0x103位置。
而存储地址内的排列则有两个通用规则:
一个多位的整数将按照其存储地址的最低或最高字节排列。如果最低有效字节在最高有效字节的前面,则称小端序;反之则称大端序。俗称小端格式与大端格式,简单来定义:
大端格式:字数据的高字节存储在低地址中,而字数据的低字节则存放在高地址中。
小端格式:与大端存储格式相反,在小端存储格式中,低地址中存放的是字数据的低字节,高地址存放的是字数据的高字节。
例如,16bit宽的数0x1234在Little-endian模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:
内存地址 | 0x4000 | 0x4001 |
存放内容 | 0x34 | 0x12 |
Big-endian模式Little-endian相反,与CPU内存中的存放方式则为:
内存地址 | 0x4000 | 0x4001 |
存放内容 | 0x12 | 0x34 |
嵌入式的面试中有时会让你写个程序判断机器是大端格式还是小端格式,可以这样写:
int check_little_dian(void)
{
union{
long a;
char b[sizeof(long)];
}u;
u.a = 1;
reutrn u.b[0];
}
返回1表示为小端格式,