大小端定义
大端存储模式:数据的低位保存在内存的高地址中,数据的高位保存在内存的低地址中。
小端存储模式:数据的低位保存在内存的低地址中,数据的高位保存在内存的高地址中。
如:int a = 1
大小端之分起因
计算机系统中是以字节为单位的,每个地址单元对应着一个字节。但是对位数大于8位的处理器,其寄存器宽度大于一个字节,就必然存在着一个如何将多个字节安排的问题,就导致了大端存储模式还是小端存储模式。
问:至于为什么在一个字节单元里存放的是两个数字?
答:0x开头表示16进制数字,一个16进制数为4个二进制数,即0x0对应的二进制数是0000,0xF对应的二进制数是1111,所以两个16进制就是8个bit位,表示一个字节。
而int类型变量占4个字节,以16进制表示为 int a = 0x1,所以针对大端存储模式每个内存单元中的存放形式为: 低地址->高地址:0x00 0x00 0x00 0x01.
判断机器的大小端
如,int a = 1,以16进制表示为0x01,只需要将低字节地址里的内容取出,就可判断存储方式
1.使用指针,将int类型强转换为char单字节类型
首先将a的地址强制转换为char类型的字符指针,再将char类型的指针赋值给指针变量p,就可以按字节访问内存中的数据。
#include <stdio.h>
void main()
{
int a = 1;
char* p = (char*)&a;
if (*p == 1)
printf("小端");
else
printf("大端");
return 0;
}
2.使用联合体
利用union结构体,同一时间内只有一个成员占有内存的特性。大端存储符合阅读习惯。
#include <stdio.h>
int main()
{
union w
{
int a;
char b;
}c;
c.a = 1;
if(c.b == 1)
printf("小端存储\n");
else
printf("大端存储\n");
return 0;
}
a和c公用同一片内存区域,所以更改c,必然会影响a的数据,当给int类型数据赋值时,char类型的数据也会有相应的值,但char类型数据只读取一个字节,所以可以用来判断大小端。