永发信息网

Little-Endian 到底是怎么排序的?

答案:3  悬赏:0  手机版
解决时间 2021-01-21 15:37
Little-Endian 到底是怎么排序的?
最佳答案
看这个就明白了,希望有用。

Big-Endian 和 Little-Endian 字节排序

字节排序 含义
Big-Endian 一个Word中的高位的Byte放在内存中这个Word区域的低地址处。
Little-Endian 一个Word中的低位的Byte放在内存中这个Word区域的低地址处。

必须注意的是:表中一个Word的长度是16位,一个Byte的长度是8位。如果一个数超过一个Word的长度,必须先按Word分成若干部分,然后每一部分(即每个Word内部)按Big-Endian或者Little-Endian的不同操作来处理字节。

一个例子:
如果我们将0x1234abcd写入到以0x0000开始的内存中,则结果为
big-endian little-endian
0x0000 0x12 0xcd
0x0001 0x34 0xab
0x0002 0xab 0x34
0x0003 0xcd 0x12
(注意:0xab换算成2进制是10101011,是个8bit的数。)

详细介绍如下:

不同体系的CPU在内存中的数据存储往往存在着差异。例如,Intel的x86系列处理器将低序字节存储在起始地址,而一些RISC架构的处理器,如IBM的370主机使用的PowerPC或Motorola公司生产的CPU,都将高序字节存储在起始位置。这两种不同的存储方式被称为little-endian和big-endian。

little-endian是x86系列CPU的数据存储方式,即将低序的部分存储在前面。而big-endian是将高序部分存储在前面。例如,要存储0xF432,little-endian将以32F4存储,而使用big-endian与此相反,将存储为F432,如图13.2所示。

程序p13.1.c讲解了如何判断系统是使用big-endian还是little-endian实现数据存储的。程序中使用的方法如下所示。

图13.2 big-endian与little-endian方式数据存储示例

(1)利用联合的特点。联合中的数据成员是共享存储空间的,所分配的空间为数据成员中最大所需的内存数。程序定义了名为endian_un的联合体,其中包含两个数据成员,一个是short类型的数据成员(在32位系统上,short类型的长度是2字节),一个是字符类型的字符数组,字符数组的元素个数为short类型的字节数。

程序将var赋值为0x0102。由于联合结构的特点,bits字符串数组中同样存储了0x0102这一数值。通过判断字符串中的低位和高位存储的内容,就可以知道系统是little-endian还是big-endian的。

(2)通过强制类型转换实现。程序中通过取flag变量的地址,获得起始空间的存储内容。如果起始空间存储的是数据的低位内容,则表示存储方式为little-endian,否则为big-endian。

程序的具体代码如下:

//p13.1.c 判断big-endian与little-endian#include //使用类型的强制转换实现little-endian与big-endian的判断int is_little_endian(void){ unsigned short flag=0x4321;if(*(unsigned char*)&flag==0x21)return 1;elsereturn 0;}int main(void){//利用联合的特点来判断little-endian与big-endianunion endian_un{short var;char bits[sizeof(short)];};union endian_un flag;flag.var=0x0102;//判断低位和高位的存储内容,确定是何种方式if(sizeof(short)==2){if(flag.bits[0]==1 && flag.bits[1]==2)printf("judged by first method, big-endian/n");else if(flag.bits[0]==2 && flag.bits[1]==1)printf("judged by first method, little-endian/n");elseprintf("cannot determine the type/n");}if(is_little_endian())printf("judged by second method, little-endian/n");elseprintf("judged by second method, big-endian/n");return 0;}

使用gcc编译p13.1.c,获得名为p13.1的可执行文件。执行该程序,具体输出如下。可以看到x86系统的内存数据存储方式为little-endian方式。

[program@localhost charter13]$ gcc -o p13.1 p13.1.c [program@localhost charter13]$ ./p13.1 judged by first method, little-endianjudged by second method, little-endian[program@localhost charter13]$

之所以介绍big-endian和little-endian,是因为这一数据存储方式不仅影响程序在不同硬件平台中的移植,而且在网络编程中也要考虑字节顺序的问题。为了避免兼容性的问题,网络中的数据传输都使用了从高到低的顺序存储方式。因此,如果要将数据从低位字节优先(little-endian)的机器上发往网络,必须首先进行转换。而big-endian的机器是不需要转换的。

Linux系统提供了htons、htonl、ntohs、ntoh这4个函数用于进行字节顺序的转换。其中,h是host的缩写,n表示network。最后一个字符如果是s,表示short类型,如果是l,表示为long类型。4个函数的具体定义如下:
uint32_t htonl(uint32_t hostlong);
uint16_t htons(uint16_t hostshort);
uint32_t ntohl(uint32_t netlong);
uint16_t ntohs(uint16_t netshort);

htonl/htons:表示主机字节顺序转换成网络字节顺序,htonl函数和htons函数的区别在于参数长度存在差异。

ntohl/ntohs:表示网络字节顺序转换成主机字节顺序,ntohl函数和ntohs函数的区别在于参数长度存在差异。
全部回答
0xF50C00FD 在little-endian下,排序是, FD 00 0C F5. 即 低位在前。
0xF50C00FD 在big-endian下, 排序是, F5 0C 00 FD, 即 高位在前
排序只有两种1.从大到小排序,2.从小到大排序。
显然这里是从小到大排序(无符号数),从一个二进制数(把16进制装换为二进制数)的最高位一次做减法cmp,再根据标志位c的判断两个数的大小关系,00<0C特殊情况的:1.指针地址的比较,2.数组标度的比较,这两种情况比较的是存放内容的地址大小,所以在没有看到你给的这个结果的问题之前不排除有以上两种特殊情况的可能性
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
家里录音设备
厂房出租是什么意思
若1+x+x²+x³=0,求x+x²+x³
现在做餐饮的如果推广的话都怎么推广比较有效
上海英伦车11年的能卖多少钱
松毛虫吐白丝是什么原因
翼闸为什么广受欢迎?翼闸品牌和研拓利是什么
lol审判天使符文 说清楚点 叫什么符文 什么用
洛阳三轮、摩托车车牌3w209是什么
从文林到扬州瘦西湖有多少公里汽车怎么走
自适应巡航可以后加装吗 汽车本来带定速巡航
2o15属蛇女人明日财运
我结婚不想让同学去送我,他们说要去送我怎么
3.2小时=________小时________分?????2吨60千
水表显示3.6是多少吨水
推荐资讯
五金机电生意经 如何让客户买你的账
I'll give you my ferend's home add
女生 14岁 身高162 体重88斤 上胸围76 下胸围
湾南农居自行车租赁点地址在哪,我要去那里办
锦州哪回民手切羊肉好吃
英语单词重怎么拼写
新人,问个台服问题:能用模拟器在电脑玩台服
从上海祁安路738终点站怎么样才能坐地铁6号线
宣城的经济与蚌埠相比
敢不敢测智商,一道幼儿园升小学的题目在朋友
用“独特的生活经历”作开头,重组下面这个句
外国人跟中国人结婚拿中国永居 有成功的么
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?