目录
一、引入大小端
在我们经常使用的VS2019编译器使用过程过,我们经常会查看变量的内存
例如
int main()
{
int a = 10;
int b = -10;
return 0;
}
内存: 0x00 00 00 0a
我们观察编译器中的字节序
内存:0xff ff ff f6
编译器中的字节序:
我们再看一个:
int main()
{
int a = 0x11223344;
return 0;
}
我们发现编译器中的存储方式与我们写出来的地址存储的顺序相反,怎么解释这种现象呢?我们就引入了大小端存储。
二、什么是大小端?
大端(存储)模式:是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中。
小端(存储)模式:是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。
我们其实可以知道,超过一个字节序就会有排放的顺序问题。
错乱的顺序我们不好处理,所以就只剩下了正着存储和倒着存储。
因此我们定义:
通俗来说:
三、为什么会有大端和小端?
为什么会有大小端模式之分呢?
这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8 bit的char之外,还有16 bit的short型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。
四、测试当前机器的字节序
我们知道存储方式无非大端存储和小端存储两种方式
因此我们可以用1来进行举例,我们知道1在内存中
无非一下两种存储方式
因此我们可以发现,我们可以通过第一个字节来进行判断,如果是1,则是小端存储;如果是0则是大端存储。
代码实现:
int main()
{
int a = 1;
char* p =(char*) &a;//int*
if (*p == 1)
{
printf("小端\n");
}
else
{
printf("大端\n");
}
return 0;
}
我们能够发现Vs2019是小端存储。
我们可以将代码进行优化:
int check_sys()
{
int a = 1;
char* p = (char*)&a;
/*if (1 == *p)
return 1;
else
return 0;*/
/*return *p;*/
return *(char*)&a;
}
int main()
{
int ret = check_sys();//返回1是小端,返回0是大端
if (1 == ret)
printf("小端\n");
else
printf("大端\n");
return 0;
}
我们也可以直接看内存:
我们发现是倒着存,所以推断出是小端。
结论:通过本篇博客的总结,我们知道了当前编译器是大端存储还是小端存储,对我们以后的学习分析过程也会有很大的帮助。
如果你还不知道你经常使用的编译器是怎样的存储方式。小伙伴们快测试起来吧~
最后,大家觉得本篇文章对你有所帮助的话,点赞收藏+关注哦~