浅谈大小端

 一般是如何看待一个类型的呢?我们应该从以下两个方面去考虑:

1>开辟空间的大小  2>如何识别内存中的数据

我们要想知道数据在内存中是如何存储的,以及怎样去识别,就要了解大小端。

 可是为什么会有大小端之分?

因为在计算机系统中,是以字节为单位的,每个地址单元对应一个字节,
我们知道一个字节占8个bit位,除了8bit的char,还有16bit的short,32bit的int,
它们不只占一个字节,除此之位,超过8位的处理器,其寄存器宽度大于一个字节,
那这些数据是如何存储的,计算机又是如何安排这些字节呢?这就导致了导致了大端和小端存储模式。

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

总结:数据有高位、低位之分,内存有高地址、低地址之分,数据低位存低地址就是小端,简单来说,就是小(数据地位)小(低地址)小(小端)。


如何去判断当前机器是大端还是小端存储模式?

有两种方法:

#include <stdio.h>
//判断一个机器是大端还是小端
int check_sys2()
{
	union
	{
		int i;
		char c;
	}un;
	un.i = 1;
	return un.c;
}
int check_sys()
{
	int i = 1;
	return (*(char*)&i);
}
int main()
{

	int ret = check_sys2();
	if (ret == 1)
	{
		printf("小端\n");
	}
	else
	{
		printf("大端\n");
	}
	return 0;
}

我在我的windows和linux系统下试了,都是小端。结果如下: 

 window:

Linux:

猜你喜欢

转载自blog.csdn.net/y6_xiamo/article/details/81277226