大端模式与小端模式
一、概念及详解
在各种体系的计算机中通常采用的字节存储机制主要有两种: big-endian和little-endian,即大端模式和小端模式。
先回顾两个关键词,MSB和LSB:
MSB:Most Significant Bit ------- 最高有效位
LSB:Least Significant Bit ------- 最低有效位
大端模式(big-edian)
big-endian:MSB存放在最低端的地址上。
举例,双字节数0x1234以big-endian的方式存在起始地址0x00002000中:
在Big-Endian中,对于bit序列中的序号编排方式如下(以双字节数0x8B8A为例):
小端模式(little-endian)
little-endian:LSB存放在最低端的地址上。
举例,双字节数0x1234以little-endian的方式存在起始地址0x00002000中:
在Little-Endian中,对于bit序列中的序号编排和Big-Endian刚好相反,其方式如下(以双字节数0x8B8A为例):
二、数组在大端小端情况下的存储:
以unsigned int value = 0x12345678为例,分别看看在两种字节序下其存储情况,我们可以用unsigned char buf[4]来表示value:
Big-Endian: 低地址存放高位,如下:
Little-Endian: 低地址存放低位,如下:
三、大端小端转换方法:
Big-Endian转换成Little-Endian如下:
#define BigtoLittle16(A)
#define BigtoLittle32(A)
四、大端小端检测方法:
如何检查处理器是big-endian还是little-endian?
联合体union的存放顺序是所有成员都从低地址开始存放,利用该特性就可以轻松地获得了CPU对内存采用Little-endian还是Big-endian模式读写。
网络字节顺序
1、字节内的比特位不受这种顺序的影响
2、大于1个字节的数据类型才有字节顺序问题
3、大于1个字节的数据类型的字节顺序有两种
网络字节顺序与主机字节顺序NBO与HBO
相关网络函数
htonl()
简述:
注释:
返回值:
inet_ntoa()
简述:
将网络地址转换成“.”点隔的字符串格式。
#include <winsock.h>
char FAR* PASCAL FAR inet_ntoa( struct in_addr in);
in:一个表示Internet主机地址的结构。
注释:
本函数将一个用in参数所表示的Internet地址结构转换成以“.” 间隔的诸如“a.b.c.d”的字符串形式。请注意inet_ntoa()返回的字符串存放在WINDOWS套接口实现所分配的内存中。应用程序不应假设该内存是如何分配的。在同一个线程的下一个WINDOWS套接口调用前,数据将保证是有效。
返回值:
若无错误发生,inet_ntoa()返回一个字符指针。否则的话,返回NULL。其中的数据应在下一个WINDOWS套接口调用前复制出来。
网络中传输的数据有的和本地字节存储顺序一致,而有的则截然不同,为了数据的一致性,就要把本地的数据转换成网络上使用的格式,然后发送出去,接收的时候也是一样的,经过转换然后才去使用这些数据,基本的库函数中提供了这样的可以进行字节转换的函数,如和htons() htonl() ntohs() ntohl(),这里n表示network,h表示host,htons() htonl()用于本地字节向网络字节转换的场合,s表示short,即对2字节操作,l表示long即对4字节操作。同样ntohs()ntohl()用于网络字节向本地格式转换的场合。
inet_ntoa() 将网络字节序地址转换成“.”点隔的字符串格式
inet_addr() 将“.”点隔字符串地址转换成网络字节序地址
htonl() 将主机字节序转换为网络字节序 long
ntohl() 将网络字节序转换为主机字节序 long
htons() 将主机字节序转换为网络字节序 short
ntohs() 将网络字节序转换为主机字节序 short
intel cpu的主机数据是小端存储模式
网络传输是大端存储模式
小端存储模式 0x1234H 34H存在低地址,12H存在高地址
大端存储模式 0x1234H 34H存在高地址,12H存在低地址
转自:http://blog.sina.com.cn/s/blog_52574bc101012wkd.html