大端模式:字数据的高字节存储在低地址中,而字数据的低字节则存放在高地址中。
小端模式:与大端存储模式相反,低地址中存放的是字数据的低字节,高地址存放的是字数据的高字节。
例如,16位宽的数0x1234在小端模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:
| 内存地址 | 0x4000 | 0x4001 |
| 存放内容 | 0x34 | 0x12 |
而在大端模式CPU内存中的存放方式则为:
| 内存地址 | 0x4000 | 0x4001 |
| 存放内容 | 0x12 | 0x34 |
我们常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。
测试大小端代码:
int main()
{
short int x;
char x0,x1;
x=0x1122;
x0=*((char*)&x); //低地址单元 ,或者((char*)&x)[0];
x1=*((char*)&x + 1); //高地址单元,或者((char*)&x)[1];
printf("x0=%x\nx1=%x\n",x0,x1);
}
若x0=0x11,则是大端; 若x0=0x22,则是小端
另外一种理解方式是:
对于一个十六进制数0×1122
使用小端(Little Endian)方式存储数据时,数据的LSB相对最没意义的数据位,存放在低地址位置,这里的LSB也就是22了.也即
低地址存储0×22, 高地址存储0×11
而使用大端(Big Endian)方式存储数据时,数据的MSB最有意义的数据位,存放在低地址位置,这里的MSB也就是11了.也即
低地址存储0×11, 高地址存储0×22
MSB:Most Significant Bit ——最高有效位
LSB:Least Significant Bit ——最低有效位
参考博客:https://blog.csdn.net/Lu597203933/article/details/44831543

9824

被折叠的 条评论
为什么被折叠?



