C/C++之大端模式和小端模式

本文介绍了ByteEndian的概念,即数据在内存中的排列方式,并探讨了大端与小端两种不同的存储方式。通过实例说明了不同字节序下多字节对象在内存中的存储差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Byte Endian是指字节在内存中的组织,所以也称它为Byte Ordering或Byte Order。对于数据中跨越多个字节的对象, 我们必须为它建立这样的约定:

(1) 它的地址是多少?

(2) 它的字节在内存中是如何组织的?

对于跨越多个字节的对象,一般它所占的字节都是连续的,它的地址等于它所占字节最低地址。(链表可能是个例外, 但链表的地址可看作链表头的地址)。比如: int x,它的地址为0×100。那么它占据了内存中的0x100, 0×101, 0×102, 0×103这四个字节(32位系统,int占用4个字节)。

上面只是内存字节组织的一种情况,多字节对象在内存中的组织一般有两种约定。 例如一个W位的整数,它的各位表达如下:[Xw-1, Xw-2, ... , X1, X0],它的MSB(Most Significant Byte)为 [Xw-1, Xw-2, ... Xw-8];LSB (Least Significant Byte)为 [X7,X6,..., X0]。LSB和MSB谁位于内存的最低地址,即谁代表该对象的地址,这就引出了大端(Big Endian)与小端(Little Endian)的问题

32位宽的数0x12345678在小端模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:

内存地址

0x4000

0x4001

0x4002

0x4003

存放内容

0x78

0x56

0x34

0x12

而在大端模式CPU内存中的存放方式则为:

内存地址

0x4000

0x4001

0x4002

0x4003

存放内容

0x12

0x34

0x56

0x78

首先我们要知道一点,内存地址是从小到大顺序增长的。因此,如果定义一个变量,变量的地址就是0x4000。采用大端方式进行数据存放符合人类的正常思维,而采用小端方式进行数据存放利于计算机处理。下面通过程序判断大小端

联合体测试大端小端

使用指针强制转换

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ZC·Shou

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值