0
点赞
收藏
分享

微信扫一扫

[ C语言 ] 一篇带你了解大小端


目录

​​一、引入大小端​​

​​二、什么是大小端?​​

​​三、为什么会有大端和小端?​​

​​四、测试当前机器的字节序​​

一、引入大小端

在我们经常使用的VS2019编译器使用过程过,我们经常会查看变量的内存

例如

int main()
{
int a = 10;
int b = -10;

return 0;
}

[ C语言 ] 一篇带你了解大小端_大小端

[ C语言 ] 一篇带你了解大小端_字节序_02

 内存: 0x00 00 00 0a

我们观察编译器中的字节序

[ C语言 ] 一篇带你了解大小端_编译器_03[ C语言 ] 一篇带你了解大小端_大小端_04

[ C语言 ] 一篇带你了解大小端_大小端_05

 内存:0xff ff ff f6

编译器中的字节序:

[ C语言 ] 一篇带你了解大小端_大小端_06

我们再看一个:

int main()
{
int a = 0x11223344;

return 0;
}

[ C语言 ] 一篇带你了解大小端_大小端_07

 [ C语言 ] 一篇带你了解大小端_大小端_08

我们发现编译器中的存储方式与我们写出来的地址存储的顺序相反,怎么解释这种现象呢?我们就引入了大小端存储。

二、什么是大小端?


大端(存储)模式:是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中。

小端(存储)模式:是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。


 我们其实可以知道,超过一个字节序就会有排放的顺序问题。

[ C语言 ] 一篇带你了解大小端_字节序_09

错乱的顺序我们不好处理,所以就只剩下了正着存储和倒着存储。

因此我们定义:

[ C语言 ] 一篇带你了解大小端_大小端_10

通俗来说:

 [ C语言 ] 一篇带你了解大小端_编译器_11

三、为什么会有大端和小端?


为什么会有大小端模式之分呢?

这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8 bit的char之外,还有16 bit的short型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。


四、测试当前机器的字节序

我们知道存储方式无非大端存储和小端存储两种方式

[ C语言 ] 一篇带你了解大小端_大小端_12

 因此我们可以用1来进行举例,我们知道1在内存中

[ C语言 ] 一篇带你了解大小端_字节序_13

无非一下两种存储方式[ C语言 ] 一篇带你了解大小端_大小端_14

 因此我们可以发现,我们可以通过第一个字节来进行判断,如果是1,则是小端存储;如果是0则是大端存储。

代码实现:

int main()
{
int a = 1;
char* p =(char*) &a;//int*
if (*p == 1)
{
printf("小端\n");
}
else
{
printf("大端\n");

}
return 0;
}

[ C语言 ] 一篇带你了解大小端_编译器_15

 [ C语言 ] 一篇带你了解大小端_大小端_16

我们能够发现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;
}

[ C语言 ] 一篇带你了解大小端_编译器_17

我们也可以直接看内存:

[ C语言 ] 一篇带你了解大小端_大小端_18

我们发现是倒着存,所以推断出是小端。

结论:通过本篇博客的总结,我们知道了当前编译器是大端存储还是小端存储,对我们以后的学习分析过程也会有很大的帮助。

如果你还不知道你经常使用的编译器是怎样的存储方式。小伙伴们快测试起来吧~

(本篇完)


举报

相关推荐

0 条评论