大端字节序和小端字节序

1.字节序是什么?

字节序是以字节为单位,讨论存储顺序的。

2.大端字节序 —— 把一个数据的低位字节的内容,存放在低地址处,把一个数据的高位字节内容存放在高地址处。

3.小端字节序—— 把一个数据的高位置字节的内容,存放在低地址处,把一个数据的低位字节内容存放在高地址处。

为什么会有大端字节序和小端字节序这大小端模式之分呢?

因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节8bit。在c语言中,除了8bit的char型外,还有16bit的short型,32bit的int型和64bit的long型(看具体编译器,有些编译器的long是32bit)

对于位数大于8位的计算器,比如16位或者32位处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多字节安排的问题,因此就有了大端存储模式和小端存储模式。

例如:

一个16bit 的short 型x,在内存中地址为0x0010 (假设) 其中x存放的值为0x1122

那么此时0x11 (数据的高位,可以类比十进制110 其中最左边的1是百位,第二个1是十位,都是权重高的数位)为高字节

0x22 为低字节

对于大端模式 ,就将0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中

小端模式则刚好相反 0x11放在高地址 0x0010, 0x22放在低地址中,即0x0010

常见的大端小端模式

我们常用的x86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以用硬件选择是大端模式还是小端模式

这时应该会有人有疑问了,大小端模式的选择有什么区别吗?会有某些情况下大端模式会比小端模式更有优势吗?

其实是没有区别的。只是一个存储习惯上的区别而已。至于现在有大端和小端两种模式,则是历史遗留问题。即早期计算机开发的时候,并没有大佬出来统一用哪种存储模式。就像当年春秋战国时期没有大一统的时候,各国的货币,文字等等都是不同的。直到后来秦始皇统一了六国,书同文,车同轨。

测试是大端模式还是小端模式代码

char*强制转换类型 只读取一个字节

会读取到最左边的字节数据

ps:至少2个字节以上的才有顺序可言,不要创造成char字符类型的数据来进行测试。

整型 1 的原码是00000000 00000000 00000000 00000001

以上是二进制位的表示方式,而4个二进制位转化1个十六进制位

所以整型1 的十六进制表示为

0x00 00 00 01 (红色为高字节,蓝色为低字节)

大小端模式存储区别如下图

(假设低地址在左,高地址在右)

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值