编者:李国帅
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。