目录
1. 什么是大端、小端
大端存储模式:数据的低位保存在高地址中,数据的高位保存在低地址中。
读完后你可能会说:听君一席话,听君一席话。(滑稽)
举例看看:
比如我们写这样一行代码,也就是创建一个局部变量
int example = 0x12345678;
在这里我用十六进制的数字赋值给一个整型变量,是因为过一会我们便于比较区别:
首先,简单说明一下:在日常生活中,456这个数字从右至左依次是个十百,由低位到高位,是按权重算,456是十进制数字,(左至右)依次是10^0,10^1······
由此可推,0x12345678中1是高位,8是低位。
所谓的大端存储模式就是
先在高地址处存放了低位的78(十六进制)
(这里为什么是78,因为78是两个十六进制位,也就是一个字节。为什么是1个字节:4个bit位最大为1111也就是十进制的十六,所以一个十六进制数字是四个bit位,两个十六进制数字就是8bit位)
依次由高地址向低地址存放每一位,最终:
小端存储模式:数据的低位保存在低地址中,数据的高位保存在高地址中。
那么,小端模式存储的图:
2.为什么要有大小端的区分
为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8 bit。但是在C语言中除了8 bit的char之外,还有16 bit的short型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。
例如:一个 16bit 的 short 型 x ,在内存中的地址为 0x0010 , x 的值为 0x1122 ,那么 0x11 为高字节, 0x22 为低字节。对于大端模式,就将 0x11 放在低地址中,即 0x0010 中, 0x22 放在高地址中,即 0x0011 中。小端模式,刚好相反。我们常用的 X86 结构是小端模式,而 KEIL C51 则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。
3. 百度2015年系统工程师笔试题:
请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序。
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int check_system(void)
{
int i = 1;
int* p = &i;
return *(char*)p;
}
int main(void)
{
if (check_system() == 1)
{
printf("小端\n");
}
else
{
printf("大端\n");
}
return 0;
}
如果是大端:
小端则为1。vs2022测试如图: