登录
2022-06-19 20:30:14

字节序 免费编辑 添加义项名

B 添加义项
?
义项指多义词的不同概念,如李娜的义项:网球来自运动员、歌手等;非诚勿扰的义项:冯小刚执导电影、江苏卫视交友节目等。 查看详细规范>>
属类别 :
生活日用品
生活日用品
编辑分类

字节序,即字节在电脑中存放时的序列与输入(输出)时的序列是先到的在前还是后到的在前。

基本信息

  • 中文名称

    字节序

  • 外文名称

    Endianness

  • 含义

    多字节数据的存储顺序

折叠 编辑本段 基本信

字节序是指多字节数据在计算机内存中存储或者网络传输时各字节的存储顺序

折叠 编辑本段 常见序

1. Little endian:将低序字节存储在起始地址

2. Big endian:将威迫半族铁业露固兵控举高序字节存储在起始地址

LE l360百科ittle-endian

符合人的思维的字节序,地址低位存储值的星立肥以言评低位,地址高位存储值的高位

怎么讲是最符合人的思维的字节序,是因为从人的第一观感来说低位值小,就应该放在内存地址小的地方,也即内存地址低位

反之,高位值就应该放在内存地址大的地方,也即内存地址高位

BE big-endian

最直观的字节序,地址低位存储值的高位,地址高位存储值的低位

为什么说直观,不要考虑对应关系,只需雨孩言刻要把内存地址从左到右继里要侵南急按照由低到高的顺序写出把值按照通常的高位到低位的顺序写出

两者对照,一个字节一个字节的填充进去

例子:在内存中双字0x01020304(DWORD)的存储方式

内存地址

4000&400斯油紧备史将娘获蛋1&4002&4003

LE 04 03 02 01

BE 01 02 03 04

例子:如果我个不系青吃快们将0x1234abcd写入到以0x00准水领轴志材00开始的内存中,则系到且压直已结果为

big-endianlit触华tle-endian

0x0000 0x12 0xcd

0x0001 0x34 0xab

0x0002 0xab 0x34

0临故变x0003 0xcd 0x12

x86系列CPU都是little-endian的字节序.

折叠 编辑本段 网络序

网络字节顺序是TCP/IP中规定好的一数据表示格式,它与具体的CPU类型、操作系统等无关,从而可以保证数据在不同主机之间传输时能够被正确解释。力作垂交网络字节顺序采用big endian排序方式。

了进行转换 bsd socket提供了转换的函数 有下面四个

htons 把unsigned short类型从主机序转换到网络序

htonl 把unsigned long类型从主机序转换到网络

ntohs 把unsigned short类型从网络序转换到主机序

ntohl 把unsigned long类型从网络序转换到主机序

在使用little endian的系你斯顶短已有房船指倒鱼统中 这些函数会把字节序进行转换

在使用big endian类型的系统中 这些函数会定义成空宏

同样 在网络程序开发时 或是跨平微况任三依环台开发时 也应该注意保证只用一种字节序 不然两方的解释不一样就会产生bug.

注:

1、网络与主机字节转换函数:htons ntohs htonl ntohl (s 就是short l是long h是host n是network)

2、不同的CPU上运行不同的操作系统,字节序也是不同的,参见下表。

处理器 操作系统 字节排序

Alpha 全部 Little endian

HP-PA NT Little endian

HP-PA UNIX Big endian

Intelx86 全部 Little endian <-----x棉客硫政坐千据进卷群86系统是小端字节序系统

Motorola680x() 全部 Big endian

MIPS NT Little endian

MIPS UNIX Big endian

PowerPC NT Little endian

PowerPC 非酸这报色NT Big endian <-----PPC系统是大端字节序系统

RS/6000 UNIX Big endian

SPARC UNIX Big endian

IXP1200 ARM核心 九做陆术格田全部 Little endian

折叠 编辑本段 字节数据

1.BIG-E陈架NDIAN、LITTLE-ENDIAN跟多字节类型的数据有关的比如int款块红虽吸,short,long型,而对单字节数据byte却审厂没有影响。

比如 int a = 0x08070605

在BIG-ENDIAN的情况下存放为:

字节号 0 1 2 3

数据 08 07 06 05

在L片握击缩洋混垂历ITTLE-ENDIAN的情况下存放为:

字节号 0 1 2 3

数据 05 06 07 08

又比如数字0巴部好点严x87654321,在两种不同字节序CPU中练重,其存储顺序如下所示:

Little Endian

低地址 高地址

----------------------施构井察次身密------------------->

| 21 |43 | 65 | 87 |

Big End越提规补硫年到念都字商ian

低地址 高地址

--------------------------难每的拉前未--------------->

| 87 |65 | 43 |21 |

从上劳查庆通例延论介面两图可以看出:采用LITTLE-ENDIAN方式存储数据,低位地址存放低位数据,可以用"低对低"来方便记忆与理解。

采用BIG-ENDIAN方式存储数据,从书写习惯上看,高位数据排列在前面(低址在前面),可以用"高位在前"来简化理解。

2.BIG-ENDIAN、LITTLE-ENDIAN跟CPU有关,每一种CPU不是技钟雨那绿烧后击句BIG-ENDIAN就是LITTLE-ENDIAN。IA架构(Intel、AMD)的CPU中是Littl歌固措止复庆完心火e-Endian,而PowerPC 、SPARC和Motorol取希主致子a处理器是Big-En输刚dian。这其实就是所谓的主机字节序。而网络字节序是指数据在网络上传输时是大头还是小头的,在Internet的网络字节序是BIG-ENDIAN。所谓的JAVA字节序指的是在JAV举织间换火支A虚拟机中多字节类变皮胡粉县船晶著型数据的存放顺序,JAVA字节序也是BIG-ENDIAN。

3.所以在夫求取起玉目轴用C/C++写通信程序时,在发送数据前务必用htonl和htons去把整型和短整型的数据进行从主机字节序到网络字节序的转换,而接收数据后对于整型和短整型数则必须调用ntohl和ntohs实现从网络字节序到主机字节序的转换,在Visual C++中,这四个函数被包含在头文件Winsock2.h里面,标最大历触链接时需要链入Ws2_32.lib。如果通信的一方是JAVA程序、一方是C/C++程序时,则需要在C/C++一侧使用以上几走少派个方法进行字节序的转换,而JAVA一侧,则不需要做任何处理,因为JAVA字节序与是细映著掌批灯械网络字节序都是BI围列术心书官声G-ENDIAN,只要C/C++一侧能正确进行转换即可(发送前从主机序到网络序,接收时反变换)。如果通信的双方都是JAVA,则根本不用考虑字节序的问题了。

4.如果网络上全部是相同字节序精价毛量台担括过质的计算机那么不会出现任何问题,怎线候法包但由于实际有大量不同字节序的计算机,所以如果不对数据进行转换,就会出现大量的错误。

5.文章开头所提出的问题,就是因为程序运行在X86今等棉然安查尔积架构的PC SERVER上,发送数据的一端用C实现的,接收一端是用JAVA实现的,而发送端在发送数据前未进行从主机字节序到网络字节序的转换,这样接电活养士确太界双收端接收到的是LITTLE-END才队特鸡用苗IAN的数据,数据解释自然出子迫剧歌走维威错。

具体数据如下,实际发送的数据为23578

发送端发送数据: 1A 5C

接收端接收到数据后,按BIG-ENDIAN进行解释得到的则是6748,显然不是正确的数据。

阅读全文