- 1. 大小端
- 1.1 什么是大小端
- 1.2 为什么要有大小端
- 1.3 怎么判断大小端
- 1.4 大小端是如何影响数据存储的
大端(字节序)模式,是指数据的低权值位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;
小端(字节序)模式,是指数据的低权值位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。
我们知道数据存储在内存中,地址有高低之分;而数据按字节为单位划分的时候,也会有对应的权值大小之分。比如一个数据0x12 34 56 78,那么1的权值是比8要高的,为什么?就好比数字1002,千位上的1权值要比个位的2高。所以大小端对应的其实就是数据和空间的对应关系,地址高低是以空间的视角来看待,而权值大小是以数据的视角看待。
1.2 为什么要有大小端大小端存储方案,本质是数据和空间按照字节位单位的一种映射关系
生产硬件的厂家的设计方式实现方式有很多种,他们都无法用自己的方式说服对方统一使用大/小端存储模式,所以大/小端仍存在分歧,但即使这样,只要按照了大/小端对应的存储/读取方式来处理数据,是没有太大影响的。
1.3 怎么判断大小端- 有了上面的解释,大小端的实例就很好理解了:
首先看这段代码:它的输出分别是-10和4294967286
int main()
{
int a = -10;
printf("%d\n", a);//有符号数
printf("%u\n", a);//无符号数
return 0;
}
是什么导致这样的结果?是数据在内存空间中存储和读取的规则,这里不再赘述。但是,这里面其实也存在大小端的问题。
- -10是以小端形式存进去的,那么我们也应该以小端的形式读取出来:
从这里看得出来大小端对数据的存储和读取是有影响的; 而不仅仅考虑原反补规则,只不过这一步对于用户来说其实是不透明的,因为这取决于硬件设计厂家,所以无论哪种方式,只要能按照正常的规律存储和读取数据,就是正确的 。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)