什么是大端小端
大端(存储)模式,是指数据的低位保存在內存的高地址中,而数据的高位,保存在内存的低地址中。
小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,保存在内存的高地址中。
用下面VS2019运行代码举例
int a = 20
补码:00000000000000000000000000010100
补码换算为十六进制:0x00000014
根据下面图示,0x00000014中低位14,放在了内存的低地址中。所以当前我的计算机VS2019中采用的是小端存储。
如果十进制的20不好理解,我们将十六进制数0x11223344放入内存看一下。
是不是和上面画的小端存储的图示一样呢?
为什么有大端和小端
为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为 8bit 。但是在C语言中除了 8bit 的 char 之外,还有16bit的short型,32bit 的 long 型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。
例如一个16bit 的 short 型 x ,在内存中的地址为0x0010,x的值为0x1122,那么0x11为高字节,0x22为低字节。对于大端模式,就将0×11放在低地址中,即0×0010中,0×22放在高地址中,即0×0011中。小端模式,刚好相反。我们常用的×86结构是小端模式,而KEIL c51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。
大小端描述的是字节的顺序,而不是二进制的顺序。所以大端存储又叫大端字节序存存储模式,小端存储又叫小端字节序存存储模式
题目:设计一个程序来判断当前机器的字节序
check_sys()
{
int a = 1;
return *(char*)&a;
}
int main()
{ //返回1,小端
//返回0,小端
int ret=check_sys();
if(ret == 1)
{
printf("小端\n");
}
else
{
printf("大端\n");
}
return 0;
}