C语言 ---- 大小端

C语言 ---- 大小端,第1张

学习目标
    • 1. 大小端
      • 1.1 什么是大小端
      • 1.2 为什么要有大小端
      • 1.3 怎么判断大小端
      • 1.4 大小端是如何影响数据存储的

1. 大小端 1.1 什么是大小端

大端(字节序)模式,是指数据的低权值位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;
小端(字节序)模式,是指数据的低权值位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。

我们知道数据存储在内存中,地址有高低之分;而数据按字节为单位划分的时候,也会有对应的权值大小之分。比如一个数据0x12 34 56 78,那么1的权值是比8要高的,为什么?就好比数字1002,千位上的1权值要比个位的2高。所以大小端对应的其实就是数据和空间的对应关系,地址高低是以空间的视角来看待,而权值大小是以数据的视角看待。

大小端存储方案,本质是数据和空间按照字节位单位的一种映射关系

1.2 为什么要有大小端

生产硬件的厂家的设计方式实现方式有很多种,他们都无法用自己的方式说服对方统一使用大/小端存储模式,所以大/小端仍存在分歧,但即使这样,只要按照了大/小端对应的存储/读取方式来处理数据,是没有太大影响的。

1.3 怎么判断大小端
  • 有了上面的解释,大小端的实例就很好理解了:
1.4 大小端是如何影响数据存储的

首先看这段代码:它的输出分别是-10和4294967286

int main()
{
	int a = -10;
	printf("%d\n", a);//有符号数
	printf("%u\n", a);//无符号数
	return 0;
}

是什么导致这样的结果?是数据在内存空间中存储和读取的规则,这里不再赘述。但是,这里面其实也存在大小端的问题。

  • -10是以小端形式存进去的,那么我们也应该以小端的形式读取出来:

从这里看得出来大小端对数据的存储和读取是有影响的; 而不仅仅考虑原反补规则,只不过这一步对于用户来说其实是不透明的,因为这取决于硬件设计厂家,所以无论哪种方式,只要能按照正常的规律存储和读取数据,就是正确的 。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/3002213.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-09-27
下一篇 2022-09-27

发表评论

登录后才能评论

评论列表(0条)

保存