1.什么是字节序
定义:字节序是指多字节数据在计算机内存中存储或者网络传输时各字节的存储顺序.通常有Little-Endian(小端)与Big-Endian(大端)两种方式.
也就是说只有当数据大小大于一字节时,才有字节序可言,所以我们可以知道char类型是没有字节序的,因为它只有一个字节大小。
接着解释一下大端小端的意思,
大端储存:数据高位置保存在内存的低地址中,数据低位置保存在内存的高地址中。
小端储存:数据低位置保存在内存的高地址中,数据高位置保存在内存的低地址中。
2.大端和小端
由于系统的不同,所以我们不知道在自己的系统下,数据是大端储存还是小端储存。其实有一个很简单且精妙的判断方法,我放到文章的后半段去讲(很多大厂都拿这个当过笔试题,很值得学习
先谈谈什么是数据的高位置,比如数字645114514,它的最高位是6,其次是4,再然后是5.......也就是我们习惯的方式,从左往右边读,左边是数据的高位置,右边是数据的低位置。
那什么是内存的高位置和低位置呢?
说到这,我们就得提到栈区的特性了,在内存中栈区是向下增长的,栈顶是高地址,栈底是低地址。
我们平时创建的临时变量啦,函数啦都会存放在栈区里,比如我们创建一个整型数组,来观察一下它们在栈区的分布
可以看到a[1]存在低地址,a[3]存在高地址。
如果我们在整型里存一个16进制数字0x010FF467,如果按0x01,0x0F,0xF4,0x67的顺序来进行储存的话,就是大端储存,就像处理字符串的逻辑一样。反过来,如果按0x67,0xF4,0x0F,0x01的顺序储存,就是小端储存。
那都说到这了,到底该怎么检测我们系统是大端储存还是小端储存呢??
我们用一个整型变量a来储存1,此时变量a的储存顺序无非两种,要么大端要么小端,我们来观察一下
大端:0x00,0x00,0x00,0x01;
小端:0x01,0x00,0x00,0x00;
有没有什么发现?我们发现,当大端储存的时候,第一个字节(低地址)存的是0,当小端储存的时候,第一个字节存的是1,这样检测系统大小端的问题,就被我们转换成了检测变量a第一个字节存的是0还是1的问题,于是我们有如下代码
#include<stdio.h>
int Judge(int a)//判断函数
{
return *(char*)&a;
}
int main()
{
int a = 1;
int tmp = Judge(a);
if (a == 1)
{
printf("小端\n");
}
else
printf("大端");
return 0;
}
*(char*)&a是非常精妙的,将整型变量a的地址强制转换成char*的形式,然后再对其进行解引用,因为char型指针的访问权限只有一个字节,所以发生截断,我们便得到了变量a的第一个字节,之后再进行判断。
我是在vs2019的环境下进行测试的,可以看到我的系统是小端储存的。
本篇文章就到这里,感谢大家的支持,博主会继续加油!