在C51核心的芯片上,数据的存储方式为大端。而在PC和ARM核心的芯片上,数据存储方式为小端。
所谓大端和小端,是指数据在存储在内存空间的时候,尾端地址的高低。
为了便于记忆,不妨把大端称为高尾端,小端称为低尾端,尾端指的是该数据中低位的数据,比如0x1234中,34就是低位,12是高位。
那么高尾端就是指,尾端的地址是高位的, 比如一串内存地址为 0x21,0x22,每个地址空间内8bit存储空间(一般地址没这么短....),那么把0x1234存入该地址时,对应的排列为
地址:0x21 0x22
数据:0x12 0x34
如果有一个指针指向0x20,那么随着指针递增,先访问到的数据是0x12,然后在访问到0x34,这就是高尾端即大端的含义
那么低尾端就是跟高尾端反过来定义的,尾端的地址在低位,同样是0x1234,如果存在低尾端的内存空间中,排列就会变成下面这样
地址:0x21 0x22
数据:0x34 0x12
同样,如果有指向0x20地址的指针,那么随着指针递增,先访问到的是低位的0x34
只有不同的变量长度才能体现出高尾端与低尾端的区别,比如int型(32位)数据和short(16位)型数据,char型(8位)数据在高尾端和低尾端中是一样的,因为数据是按一个字节为单位进行存储的
在结构体中各个变量的排列顺序不会由于大小端而发生改变,只有变量自己会发生上述的变化。