【数据存储概念】大端存储&&小端存储
本文采用整形来举列子说明大端存储和小端存储的区别及原理特别注意:大小端模式是指字节序的大小端模式,当一个数据的所占的内存大于一个字节时,就会按照大端或小端顺序存储。数据存放内存中其实存放的是补码。如 int temp = 0x1122在内存中存储内容如下我们可以看到对于temp存储的是补码,但是我们发现顺序是数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。
大小端介绍
本文采用整形来举列子说明大端存储和小端存储的区别及原理
特别注意:大小端模式是指字节序的大小端模式,当一个数据的所占的内存大于一个字节时,就会按照大端或小端顺序存储。
之前学过对于整形来说:数据存放内存中其实存放的是补码。
如 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;
}

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐
所有评论(0)