一、大小端
1、为啥会有大小端
在计算机系统中以字节为单位,每个地址单位都有一个字节(一个字节8个bit位)。在C语言中,有char(8bit)、short(16bit)、long(32bit,具体看编译器)。对于位数大于8的处理器,不如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在一个如何将多个字节安排的问题。so就有了大端存储模式和小端存储模式
2、大小端的概念区分
(1)大端(Big_endian):数据的高字节保存在内存的低地址处,数据的低字节保存在内存的高地址。这个存储模式类似将数据当做字符串处理:地址由小到大增加,数据由高到低存放。
(2)小端(Little_endian):数据的高字节保存在内存的高地址处,数据的低字节保存在内存的低地址。这样子的存储模式和我们逻辑思维方式一样,将地址的高低位和数据权位有效对应起来,高地址对应权值高的,低地址对应权值低的。
提示:对于x86架构,一般网络字节序都是大端,本地字节序都是小端。
测试代码:
#include <stdio.h> #include <stdint.h> int main(int argc, char const *argv[]) { uint16_t a = 0x1234; (*(char *)&a) == 0x34 ? puts("小端系统") : puts("大端系统"); return 0; }
运行结果:
检查系统大小端:
可以看到系统就是小端
0.0分
1 人评分