文章目录
- 一、什么小端存储,什么是大端存储?
- 二、为什么有大小端之分?
- 三、通过程序判断系统是小端存储还是大端存储模式
一、什么小端存储,什么是大端存储?
小端模式(Little-endian), 是指数据的高位字节保存在内存的高地址中,而数据的低位字节保存在内在的低地址中,这种存储模式将地址的高低和数据位权有效结合起来。
大端模式(Big-endian),是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中。
如图:
二、为什么有大小端之分?
在计算机系统中,是以字节为单位的,每个地址单元都对应着一个字节,一个字节为 8bit。但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器)等数据类型。另外,对于位数大于 8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。我们常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。
这是由用途决定的,x86芯片主要用于数值计算,而51单片机主要应用于日常生活,所以对于数据更加敏感,可以更快的输出对使用者的有用信息。但是后来互联网流行,TCP/IP协议规定为大端模式,为了跨平台通信,还专门出了网络字节序和主机字节序之间的转换接口 (ntohs、htons)。
网络中采用大端模式,在网络序中,发送的顺序是从缓冲区的低地址开始的,所以将高字节首先放到低地址,可以让接收方更快的判断收到的数据是否正确并做出响应。同时,头部信息还具有其他的一些作用,比如说同步信号等。
优缺点:小端模式强制转换类型时不需要调整字节内容,直接截取低字节即可;大端模式由于符号位为第一个字节,很方便判断正负。
三、通过程序判断系统是小端存储还是大端存储模式
1.输入整形数据1(0x00000001),取地址强制转换为char*类型,解引用判断其值是1还是0,为1则为小端存储,反之为大端存储模式;
# include <stdio.h>
int check_sys()
{
int a = 1;
char *p = (char *) &a;
return *p; //返回1,小端;返回0,大端;
}
int main()
{
int ret = check_sys();
if (ret == 1)
printf("小端\n");
else
printf("大端\n");
return 0;
}
2.通过联合体的存储特点进行判断;
# include <stdio.h>
int check_sys()
{
union un
{
char c;
int i;
}u;
u.i = 1; //存入int型1;
return u.c; //用char型取出;
};
int main()
{
int ret = check_sys();
if (1 == ret)
printf("小端\n");
else
printf("大端\n");
return 0;
}