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 (红色为高字节,蓝色为低字节)
大小端模式存储区别如下图
(假设低地址在左,高地址在右)