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

在计算机系统中,存储是以字节为单位的,每个地址单元都对应着一个字节,一个字节=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
 {
  //是小端模式
 }
}

 

转载于:https://www.cnblogs.com/clumsy1006/p/5322348.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值