Little-Endian就是低位字节排放在内存的低地址端,高位字节排放在内存的高地址端
Big-Endian就是高位字节排放在内存的低地址端,低位字节排放在内存的高地址端
如:16bit宽的数0x1234在Little-endian模式(以及Big-endian模式)CPU内存中的存放方式(假设从地址0x4000开始存放)为:
字节序判断:
方法一
类型转换加解引用
BOOL IsBigEndian() { int a = 0x1234; char b = *(char *)&a; //通过将int强制类型转换成char单字节,通过判断起始存储位置。即等于 取b等于a的低地址部分 if( b == 0x12) { return TRUE; } return FALSE; }
方法二
联合体union的存放顺序是所有成员都从低地址开始存放,且所有变量共享内存。
BOOL IsBigEndian() { union NUM { int a; char b; }num; num.a = 0x1234; if( num.b == 0x12 ) { return TRUE; } return FALSE; }
网络传输中的大小端
一、为什么有大小端模式之分
在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在除了8bit的char之外,还有16bit的short型,32bit的long型等等。另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。
二、转化原因
1、不同的电脑可能使用的端模式不一样,因此进行数据传递时必须要考虑端模式的不同。
2、在我们的网络字节传输上,TCP/IP协议规定了必须使用网络字节顺序(大端模式),而在大多数的PC机上采用的是小端模式。因此如果高于8位的数据类型要进行网络传输,我们要先将数据转换为大端再进行发送,对于接收到的数据,我们要根据自己的机器存储方式进行大小端转换后再使用。
三、如何转化
对于小于等于32位的数字来说,C语言有库进行转换,例如:
ntohl() 将一个无符号长整形数从网络字节顺序转换为主机字节顺序
htonl() 将一个32位数从主机字节顺序转换成网络字节顺序
对于大于32位的数字来说,例如64位小端转大端:
/* * 64位小端转大端 */ long unsigned int hton_ll(long unsigned int data) { long host_h; long host_l; long unsigned int temp; host_l = data & 0xffffffff; host_h = (data >> 32) & 0xffffffff; temp = htonl(host_l); temp = (temp << 32) | htonl(host_h); return temp; }
标签:小端,字节,int,32,host,long,地址,c++,大端 From: https://www.cnblogs.com/cuijy1/p/16875468.html