大小端介绍
本文采用整形来举列子说明大端存储和小端存储的区别及原理
特别注意:大小端模式是指字节序的大小端模式,当一个数据的所占的内存大于一个字节时,就会按照大端或小端顺序存储。
之前学过对于整形来说:数据存放内存中其实存放的是补码。
如 int temp = 0x1122 在内存中存储内容如下
我们可以看到对于temp存储的是补码,但是我们发现顺序是数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。
大端小端存储的特征
大端(存储)模式:是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;
小端(存储)模式:是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。
由上图结合上面介绍所用VS调试窗口内容可知,VS用的存储方式为小端存储,以及我们常用的X86结构也是采用小端存储。
采用大端存储比较常见的为51单片机
如何判断大小端
由于小端存储数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。
利用这个特性可定义 int i = 1;
1:如果是小端存储,由于1的值没超过一个字节的表示范围,所以数值1必定存在于最低的字节中。
2:如果是大端存储,所以数值1必定存在于最高的字节中。
3:根据前两点,只要我们取最低字节并判断是否为1即可
int main()
{
int i = 1;
char cur = (char)i;
if (cur == 1)
printf("我是小端存储\n");
else
printf("我是大端存储\n");
return 0;
}