linux网络编程一:主机字节序与网络字节序的的判断

        最近在看《linux高性能服务器编程》,在此做个日记,以激励自己,同时分享于有需要的朋友。


        现代CPU的累加器一次能装载至少4字节(32位),即一个整数。那么这4字节在内存中排列的顺序将影响它被累加器装载成的整数值,这就是字节序问题。

        字节序分大端字节序(big endian)和小端字节序(little endian),大端字字节序是指一个整数的高位字节(23~31bit)存储在内存的低地址外,低位字节(0~7bit)存储在内存的高地址处。 小端字节序则是指整数的高位字节存储在内存的高地址处,而低位字节存储在内存的低地址处。

        现代PC大多采用小端字节序,因此小端字节序又被称为主机字节序。

        当格化数的数据在两台使用不同字节序的主机之间直接传递时,接收端必然错误解释之。解决方法是:发送端总是把要发送的数据转化成大端字节序数据后再发送,而接收端知道对方传送过来的数据总是采用大端字节序,所以接收端可以根据自身采用的字节序决定是否对接收到的数据时行转换。

         因此,大端字节序也称为网络字节序,它给所有接收数据的主机提供了一个正确解释收到的格式化数据的保证。

 


//用于检查机器字节序的代码:

#include <stdio.h>

void byteorder()
{
    union
    {
        short value;
        char union_bytes[ sizeof( short ) ];
    } test;
    
    test.value = 0x0102;
    
    if (  ( test.union_bytes[ 0 ] == 1 ) && ( test.union_bytes[ 1 ] == 2 ) )
    {
        printf( "big endian\n" );
    }
    else if ( ( test.union_bytes[ 0 ] == 2 ) && ( test.union_bytes[ 1 ] == 1 ) )
    {
        printf( "little endian\n" );
    }
    else
    {
        printf( "unknown...\n" );
    }
}


int main(int argc, char **argv)
{
    
    byteorder();
    
    return 0;
}



评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值