主机序也称为本地字节序,分为大端和小端
大端:低地址放大数据; 小端:低地址放小数据.网络序统一为大端
该算法主要需要测试主机序,如果是大端则不做任何的改变,如果是小端则逆序
#includebool 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("%xn", Htonl(0x12345678)); return 0; }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)