您的位置:首页 > 其它

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

2015-07-31 16:34 323 查看
在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位)数据在高尾端和低尾端中是一样的,因为数据是按一个字节为单位进行存储的

在结构体中各个变量的排列顺序不会由于大小端而发生改变,只有变量自己会发生上述的变化。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: