TCP/IP协议规定,网络中的数据流采用的是大端字节序,即低地址高字节。大端法与小端法我就不多说了,在博客http://www.blogjava.net/tinysun/archive/2009/12/31/307952.html中做了详细介绍。
不同cpu平台上字节序通常也不一样,在80X86平台上,系统将多字节中的低位存储在变量起始地址,使用小端法。为了
使网络程序具有可移植性,使同样的C代码在大端和小端计算机上编译后都能正常运行,我们可以调用以下库函数做网络字节序和主机字节序的转换。
#include <arpa/inet.h>
uint32_t htonl(uint32_t hostlong);
uint16_t htons(uint16_t hostshort);
uint32_t ntohl(uint32_t netlong);
uint16_t ntohs(uint16_t netshort);
这些函数名很好记,h表示host,n表示network,l表示长整形,s表示短整型。例如htonl表示将32的长整形从主机字节序列转为网络字节序列。
如果主机是小端字节序,这些函数将参数做相应的大小端装换后返回,如果主机是大端字节序,这些函数不做转换,将参数原样的返回
但是一般说来,我们都不需要转,我们常用的都一样。但是Java Socket与C Socket通信是需要转的。