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

在计算机系统中,存储是以字节为单位的,每个地址单元都对应着一个字节,一个字节=8bit。在C语言中除了8bitchar之外,还有16bitshort型,32bitlong型(要看具体的编译器)。对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,如何安排多个字节的存储,这就有了大端存储模式和小端存储模式。

 

 

小端:较高的有效字节存放在较高的的存储器地址,较低的有效字节存放在较低的存储器地址。 大端:较高的有效字节存放在较低的存储器地址,较低的有效字节存放在较高的存储器地址。 如果将一个16位的整数0x1234存放到一个短整型变量(short)中。这个短整型变量在内存中的存储在大小端模式由下表所示。

 

地址偏移

大端模式

小端模式

0x00

12OP0

34OP1

0x01

34OP1

12OP0

小端模式:强制转换数据不需要调整字节内容,124字节的存储方式一样。

大端模式:符号位的判定固定为第一个字节,容易判断正负。

常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARMDSP都为小端模式。

 

 

什么时候要进行大小端字节序的转换?  

 

short 或者 long的数据在进行通信的时候最好养成:  1、发送的时候使用:htonsl 2、接受的时候使用:ntohsl 而不要理会两边的通信是否需要这么做~~  当然了一般我都不用int型的数据通信,从来都是字符串通信,发送方利用sprintf组织,接收方利用atoi进行转换~~

 

 

C语言判断大小端模式

方法一:

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

方法二:

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

 

posted @ 2016-03-26 10:45  yangyuxiaozi  阅读(4099)  评论(0编辑  收藏  举报