大小端存储模式的理解和判断

在计算机系统中,存储是以字节为单位的,每个地址单元都对应着一个字节,一个字节=8bit。在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器)。对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,如何安排多个字节的存储,这就有了大端存储模式和小端存储模式。
小端:较高的有效字节存放在较高的的存储器地址,较低的有效字节存放在较低的存储器地址。****大端:较高的有效字节存放在较低的存储器地址,较低的有效字节存放在较高的存储器地址。如果将一个16位的整数0x1234存放到一个短整型变量(short)中。这个短整型变量在内存中的存储在大小端模式由下表所示。

大小端存储模式的理解和判断_第1张图片

小端模式:强制转换数据不需要调整字节内容,1、2、4字节的存储方式一样。
大端模式:符号位的判定固定为第一个字节,容易判断正负。
常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。
**什么时候要进行大小端字节序的转换?******
short或者long的数据在进行通信的时候最好养成:1、发送的时候使用:htons(l)2、接受的时候使用:ntohs(l)而不要理会两边的通信是否需要这么做 当然了一般我都不用int型的数据通信,从来都是字符串通信,发送方利用sprintf组织,接收方利用atoi进行转换
C语言判断大小端模式
方法一:

voidIsBigEndian()
{shortinta =0x1122;//十六进制,一个数值占4位charb =  *(char*)&a;//通过将short(2字节)强制类型转换成char单字节,b指向a的起始字节(低字节)if( b ==0x11)//低字节存的是数据的高字节数据{//是大端模式}else{//是小端模式}
}

方法二:

voidIsBigEndian()//原理:联合体union的存放顺序是所有成员都从低地址开始存放,而且所有成员共享存储空间{
union temp
{shortinta;charb;
}temp;
temp.a=0x1234;if( temp.b ==0x12)//低字节存的是数据的高字节数据{//是大端模式}else{//是小端模式}
}

你可能感兴趣的:(大小端存储模式的理解和判断)