int main() { int a = 0x12345678; printf("Original - 0x%x\n",(a)); printf("Network - 0x%x\n",htonl(a)); printf("Host - 0x%x\n",ntohl(a)); return 0;}
输出:
Original - 0x12345678Network - 0x78563412Host - 0x78563412解决方法
Since its an LE machine,I expect
ntohl()
to be a no-op
这是错误.网络字节顺序是big-endian,主机字节顺序是little-endian.因此,ntohl和htonl都会返回其输入的字节交换版本.
记住,htonl的观点是你可以在主机上取整数,然后写:
int i = htonl(a);
结果是i的内存,当使用网络字节顺序解释时,具有与a相同的值.因此,如果您将i的对象表示形式写入套接字,而另一端的读取器则希望以网络字节顺序排列4字节整数,则会读取a的值.
and display
0x78563412
这是你打算写的吗?如果ntohl是一个no-op(或者说是一个身份函数),那么你的第三行必然会打印与你的第一行相同的东西,因为你会有ntohl(a)== a.这是在大型实现中发生的情况,您的程序打印在哪里:
Original - 0x12345678Network - 0x12345678Host - 0x12345678总结
以上是内存溢出为你收集整理的c – 整数的htonl()和ntohl()的输出相同全部内容,希望文章能够帮你解决c – 整数的htonl()和ntohl()的输出相同所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)