大小端介绍,你知道常用的VS2019内存中字节序存储的顺序吗?

目录

一、引入大小端

二、什么是大小端?

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

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


一、引入大小端

在我们经常使用的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;
}

我们也可以直接看内存:

 

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

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

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

最后,大家觉得本篇文章对你有所帮助的话,点赞收藏+关注哦~ 

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇

)">
下一篇>>