概述
二进制文件的字节顺序:大端字节(big-endian)和小端字节(little-endian),此字节存储适用于所有数据类型,此处仅以short为例。
因为现行的计算机都是以八位一个字节为存储单位,那么一个16位的整数,也就是C语言中的short,在内存中可能有两种存储顺序big-endian和litte-endian.
考虑一个short整数0x3132(0x32是低位,0x31是高位),把它赋值给一个short变量,那么它在内存中的存储可能有如下两种情况:
大端字节(Big-endian):
----------------->>>>>>>>内存地址增大方向
short变量地址
0x1000 0x1001
_____________________________
| |
| 0x31 | 0x32
|________________ | ________________
高位字节在低位字节的前面,也就是高位在内存地址低的一端.可以这样记住(大端->高位->在前->正常的逻辑顺序)
小端字节(little-endian):
----------------->>>>>>>>内存地址增大方向
short变量地址
0x1000 0x1001
_____________________________
| |
| 0x32 | 0x31
|________________ | ________________
低位字节在高位字节的前面,也就是低位在内存地址低的一端.可以这样记住(小端->低位->在前->与正常逻辑顺序相反)
网络协议中都采用big-endian,所以所有主机往网络上传说时都需要先转换为big-endian再发送,接受时按big-endian格式解析,从而保证所有类型间主机通信的正常。
参考
最后
以上就是年轻黑米为你收集整理的大小字节序转换 c语言,大小字节序问题的全部内容,希望文章能够帮你解决大小字节序转换 c语言,大小字节序问题所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复