字节序

来源:互联网 发布:淘宝的代购可信吗 编辑:程序博客网 时间:2024/05/21 21:34

每一台主机由于体系结构的不同,所采用的数据存储方式也不想同。在网络环境中进程间的通信是要跨越主机的,这时就有了一个字节序不统一的问题。字节序依赖于具体主机的处理器体系结构,同一台主机的进程间不存在该问题。但是在网络环境中编程,程序员不能对通信两端的主机做强制性要求,这样会降低代码的通用性。


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


由此可知网络字节序其实就是大端字节序,那么是不是在大端机器上编写程序就不需要进行字节序转换呢?理论上来说这样做不会产生错误。但是从代码的移植性上来说时存在隐患的。建议大家不管那种字节序的主机都做字节序转换处理。

0 0