c语言编码实现函数long htonl(long a),也就是将主机序转化为网络序

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/hehongonghh/article/details/82663842

解析:主机序也称为本地字节序,分为大端和小端.大端:低地址放大数据;小端:低地址放小数据.网络序统一为大端
该算法主要需要测试主机序,如果是大端则不做任何的改变,如果是小端则逆序


bool IsLittle()//判断主机序是否为小端
{
    short a  = 0x0001;//小数据为0x01,高数据为0x00
    return *(char *)&a == 0x01; //低地址放小数据
}

long Htonl(long a)
{
    long b = 0;

    if( !IsLittle() )//大端
    {
        return a;
    }

    for(int i=0;i<sizeof(a);i++)//小端:0x12345678->0x78563412
    {                                        //处理单位为字节,1字节8位
        b = (b<<8) | (a & 0xff);
        a >>= 8;      
    }
    return b;
}

int main()
{
    printf("%x\n",Htonl(0x12345678));

    return 0;
}

猜你喜欢

转载自blog.csdn.net/hehongonghh/article/details/82663842