每一台主机由于体系结构的不同,所采用的数据存储方式也不想同。在网络环境中进程间的通信是要跨越主机的,这时就有了一个字节序不统一的问题。字节序依赖于具体主机的处理器体系结构,同一台主机的进程间不存在该问题。但是在网络环境中编程,程序员不能对通信两端的主机做强制性要求,这样会降低代码的通用性。
linux环境下使用四个函数进行字节序之间的转换,其函数原型如下:
#include<arpa/inet.h>
uint32_t htonl(uint32_t hostint32);
uint16_t htons(uint16_t hostint16);
uint32_t ntohl(uint32_t netint32);
uint16_t ntohs(uint16_t nettint16);
htonl函数的参数是一个32位的本地主机数据,该数据采用的是主机字节序。htonl函数将其转换为网络字节序,并且返回。htons函数和htonl函数类似,不过该函数对16位整数进行转换,ntohl和ntohs函数可以看成是前面两个函数的逆函数,其功能是将网络字节序的数据转换为主机字节序。
(1)、在编辑器中编辑程序如下:
#include <stdio.h>
#include <arpa/inet.h>
int main(int argc, char *argv[])
{
short a = htons(0x0102);
short * p = &a;
if(*((char *)p) == 0x01)
{
printf("big-endian\n");
}
else if(*((char *)p) == 0x02)
{
printf("little-endian\n");
}
else
{
printf("unkown\n");
}
return 0;
}
(2)、编辑该程序:
gcc byteOrder.c -o byteOrder -Wall
(3)、运行该程序:
./byteOrder
得到:big-endian
由此可知网络字节序其实就是大端字节序,那么是不是在大端机器上编写程序就不需要进行字节序转换呢?理论上来说这样做不会产生错误。但是从代码的移植性上来说时存在隐患的。建议大家不管那种字节序的主机都做字节序转换处理。