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