大端和小端的区别和方便记忆的方法

在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位)数据在高尾端和低尾端中是一样的,因为数据是按一个字节为单位进行存储的

在结构体中各个变量的排列顺序不会由于大小端而发生改变,只有变量自己会发生上述的变化。

你可能感兴趣的:(数据,小端,大端,低尾端,高尾端)