用发呆的时间来理清自己的思绪
分类: 嵌入式
2014-10-26 23:20:17
在Linux编程中,往往会遇到字节的网络顺序和主机顺序的问题。
这时就可能用到htons(), ntohl(), ntohs(),htons()这4个网络字节顺序与本地字节顺序之间的转换函数:
htonl()--"Host to Network Long int" 32Bytes
ntohl()--"Network to Host Long int" 32Bytes
htons()--"Host to Network Short int" 16Bytes
ntohs()--"Network to Host Short int" 16Bytes
之所以需要这些函数是因为计算机数据表示存在两种字节顺序:大端和小端
由于不同的CPU架构可能支持大端,也可能支持小端,这就造成了内存中同样的数据被不同端的cpu读取时CPU所能理解的数据可能会有所不同,比如对于0x12345678,对于大端CPU来说,在内存中的存放顺序是低地址存放高位,高地址存放低位,但是对于小端CPU而言,读取出来的数据会理解为0x87654321,刚好相反,因此为了避免这种由于cpu的“端”的不同而造成的数据的“理解错误”,才发明了网络字节序,目的在于规范各种类型的cpu在向别的cpu发送数据时必须先把自己的数据转换成网络字节序,然后别的主机在接受到数据之后再转换成适合自己cpu所支持的“端”数据,这样就保证了数据传输的正确性,以下是一些详细的解释:
网络字节顺序NBO(Network Byte Order):
按从高到低的顺序存储,在网络上使用统一的网络字节顺序,可以避免兼容性问题。
主机字节顺序(HBO,Host Byte Order):
不同的机器HBO不相同,与CPU设计有关,数据的顺序是由cpu决定的,而与操作系统无关。
如 Intel x86结构下,short型数0x1234表示为34 12, int型数0x12345678表示为78 56 34 12 。
如IBM power PC结构下,short型数0x1234表示为12 34, int型数0x12345678表示为12 34 56 78。
由于这个原因不同体系结构的机器之间无法通信,所以要转换成一种约定的数序,也就是网络字节顺序,其实就是如同power pc那样的顺序 。在PC开发中有ntohl和htonl函数可以用来进行网络字节和主机字节的转换。
在Linux系统下:htonl(),htons(), ntohl(), ntohs()的头文件及函数定义:
#include
uint32_t htonl(uint32_t hostlong);
uint16_t htons(uint16_t hostshort);
uint32_t ntohl(uint32_t netlong);
uint16_t ntohs(uint16_t netshort);
每个函数的具体功能,最好直接通过man找数据手册,然后直接看数据手册,这里只提供一个记忆函数名称的一个方法。