不同的 CPU 有不同的字节序类型 这些字节序是指整数在内存中保存的顺序 这个叫做主机序
最常见的有两种
1 . Little endian :将低序字节存储在起始地址
2 . Big endian :将高序字节存储在起始地址
LE little-endian
最符合人的思维的字节序
地址低位存储值的低位
地址高位存储值的高位
怎么讲是最符合人的思维的字节序,是因为从人的第一观感来说
低位值小,就应该放在内存地址小的地方,也即内存地址低位
反之,高位值就应该放在内存地址大的地方,也即内存地址高位
BE big-endian
最直观的字节序
地址低位存储值的高位
地址高位存储值的低位
为什么说直观,不要考虑对应关系
只需要把内存地址从左到右按照由低到高的顺序写出
把值按照通常的高位到低位的顺序写出
两者对照,一个字节一个字节的填充进去
写网络程序的时候经常会遇到网络字节顺序和主机字节顺序不一致的情况,这时就会用到下面这几个函数
htons(),htonl,ntohs(),ntohl()转换函数
htons 把 unsigned short 类型从主机序转换到网络序htonl 把 unsigned long 类型从主机序转换到网络序
ntohs 把 unsigned short 类型从网络序转换到主机序
ntohl 把 unsigned long 类型从网络序转换到主机序
注:
1 、网络与主机字节转换函数 :htons ntohs htonl ntohl (s 就是 short l 是 long h 是 host n 是 network)
2 、不同的 CPU 上运行不同的操作系统,字节序也是不同的,
另外还有两个函数在socket编程的时候会遇到
inet_ntoa();将网络地址转换成“.”点隔的字符串格式。
inet_aton();inet_aton是一个改进的方法来将一个字符串IP地址转换为一个32位的网络序列IP地址
inet_addr()的功能是将一个点分十进制的IP转换成一个长整数型数