有关字节序的问题,最早来源于Jonathan Swift书写的《格列佛游记》一书,这本书根据将鸡蛋敲开的方法不同将所有的人分为两类,从圆头开始将鸡蛋敲开的人被归为Big Endian,从尖头开始将鸡蛋敲开的人被归为Littile Endian。小人国的内战就源于吃鸡蛋时是究竟从大头(Big-Endian)敲开还是从小头(Little-Endian)敲开。
有关具体的大小端描述,想必资料网上都有,下面简要给出结果:
大端:高位存在低地址,低位存在高地址;
小端:高位存在高地址,低位存在低地址;(intel的x86,ARM普遍都是属于小端)
比如数值 0x123456
大端模式:
低地址 -------------> 高地址
0x12 | 0x34 | 0x56
小端模式:
低地址 ------------> 高地址
0x56 | 0x34 | 0x12
下面针对几个问题:(1)字符串有大小端问题吗?(2)字节内的顺序问题?(3)位域的情况又是如何?进行探讨。
(1)字符串没有大小端问题。
理由:大小端问题是针对计算机中某种类型(内置)的存储顺序。因为计算机以字节为存储单位,像一个char类型的只占一个字节,固然不需要考虑顺序问题;但是像int类型,一般占4个字节,这就存在顺序问题了。既可以从高到低,也可以从低到高。所以,才有大小端问题的出现。对于字符串,是由字符组成的(可以看成字符数组),存储的单个对象就是字符,所以不需要大小端。