字节序的理解

编者:李国帅

qq:9611153 微信lgs9611153

时间:2012/02/28 08:35:40

背景原因:

由于不同的cpu或者操作系统的主机序不一样,导致在读写文件或者文件传送的时候,使用的规则不一样。

 

问题相关:

 

多字节数据类型在不同的cpu上可能读写方式不同。

同时不同编译器对bitfield的处理方式也可能不一样。

所以数据结构中的int型和short型变量需要在网络的两头先变成相同的格式发送,接收的时候再从相同的格式转变为本机格式进行处理。

而且,数据中不要使用bitfield。

 

举例

消息头     起始码     标识符     内容格式         消息长度

8Bytes      2 Byte       1Bytes      1Byte                 4 Bytes

 

标识符     1个字节,从高至低位(7?0)标识如下:

Bit 7 – Bit 3:保留

Bit 2位:是否加密:1-消息加密,0-消息未加密

Bit 1位:是否压缩:1-消息压缩,0-消息未压缩

Bit 0位:消息是否做和校验:1-消息有和校验,0-消息未做和校验

 

标识符字段在windows和mac环境中编译之后的顺序是不同的,虽然都可能是x86机器。暂时不做修改。

 

按照约定,不管对于任何的cpu和操作系统,都知道网络上使用什么格式(网络上使用big-endian格式)。

这样,网络自身使用什么格式对主机来说是透明的,不需要管理。这里仅仅把网络顺序作为cpu中自序识别的一个参考。

对于多字节字段,发送的时候使用htons或者htonl。接收的时候使用ntohs或者ntohl。

 

 

猜你喜欢

转载自blog.csdn.net/lgs790709/article/details/84790165