再谈大端和小端

来源:互联网 发布:mac dangerous 编辑:程序博客网 时间:2024/05/19 10:39

 

1. 动手澄清

 1.1 测试代码如下:

 

1.2.  vs调试内存结构如下:

 

 可以看出 :

        摆放以字节(8bit,2个16机制)为单位。

        复合结构各个成员的顺序不变化,成员内部的字节有变化。

        基本类型int,short int等,在小端机器上低位(个位)放到低地址,高位(万位)放到高地址,大端相反。

 

2. 基本概念

 

Byte Endian是指字节在内存中的组织,所以也称它为Byte Ordering,或Byte Order。
     对于数据中跨越多个字节的对象, 我们必须为它建立这样的约定:
(1) 它的地址是多少?
(2) 它的字节在内存中是如何组织的?
    针对第一个问题,有这样的解释:
    对于跨越多个字节的对象,一般它所占的字节都是连续的,它的地址等于它所占字节最低地址。(链表可能是个例外, 但链表的地址可看作链表头的地址)。
    比如: int x, 它的地址为0x100。 那么它占据了内存中的Ox100, 0x101, 0x102, 0x103这四个字节(32位系统,所以int占用4个字节)。
    上面只是内存字节组织的一种情况: 多字节对象在内存中的组织有一般有两种约定。 考虑一个W位的整数。
    它的各位表达如下:[Xw-1, Xw-2, ... , X1, X0],它的
    MSB (Most Significant Byte, 最高有效字节)为 [Xw-1, Xw-2, ... Xw-8];
    LSB (Least Significant Byte, 最低有效字节)为 [X7,X6,..., X0]。
    其余的字节位于MSB, LSB之间。

LSB和MSB谁位于内存的最低地址, 即谁代表该对象的地址?
这就引出了大端(Big Endian)与小端(Little Endian)的问题。
如果LSB在MSB前面, 既LSB是低地址, 则该机器是小端; 反之则是大端。

 

 

3. 判断系统是大端,还是小端

原创粉丝点击