一般是如何看待一个类型的呢?我们应该从以下两个方面去考虑:
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: