一、发现问题
我们首先定义一个变量:int a = 20;那么此时,计算机会立即申请出四个字节的内存来存放这个变量a,用十六进制来表示变量a数值:0x00000014,然而我们在窗口内存中查看变量a的地址时,,发现顺序有点不对劲,这是为什么呢?
二、大小端介绍
1.什么是大小端
大端(存储) 模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中。
小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,保存在内存的高地址中。
2.为什么有大端小端?
为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位,每个地址单元都对应着一个字节,一个字节为8 bit,但是在C语言中,除了8 bit的char类型外,还有16 bit的short类型,32 /64 bit的long类型(具体看编译器),另外,对于位数大于8的处理器,例如16为或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因此就导致了大端小端存储模式。
3.(补充:什么是数据的高位,低位?)
例如十进制数1234,个位4就是低位,千位1便是高位。
同理,对于上面的变量a:0x00000014,0x14是低位,占一个字节。
4.总结:
对于上面的图:,
如果变量a的低位0x14在低地址处,当前计算机为小端模式,反之,为大端模式。
我们常用的x86结构是小端模式,KEIL C51则为大端模式。很多的ARM,DSP都为小端模式,有些ARM处理器还可以由硬件来选择是小端模式还是大端模式。
三、 一道笔试题
百度2015年系统工程师笔试题:
请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序。(10分)
分析:先创建一个变量,int a = 1;那么此时计算机分配了四个字节大小的地址来存储,我们只需得到第一个字节的地址,判断出他是否为1,如果为1,说明这个数的低位存储在了低地址处,(也就是我们所看的“倒过来存储了”),那么便是小端模式存储。
//判断计算机当前存储是小端OR大端
//返回1表示小端,返回0表示大端
int check_sys() {
int a = 1;
return *(char*)&a;
}