大小端模式的快速判断方法

大小端的问题剖析:

嵌入式系统开发者应该对Little-endian和Big-endian模式非常了解。采用Little-endian模式的CPU对操作数的存放方式是 从低字节到高字节,而Big-endian模式对操作数的存放方式是从高字节到低字节。例如,16bit宽的数0x1234在Little-endian 模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:

内存地址0x40000x4001
存放内容0x340x12

而在 Big-endian 模式 CPU 内存中的存放方式则为:

内存地址0x40000x4001
存放内容0x120x34

我们常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。

以下这段代码可以用来判断当前处理器的大小端模式

#include <stdio.h>
void main()
{
    int a = 0x01;
    char * p = (char*) & a;
union {
int i;
char j[sizeof(int)];
}test ={0xdeadbeef};
int i=0;
for(i=0;i<sizeof(int);i++){
printf("test.j[%d] = 0x%x\n",i,test.j[i]);
}
    if(*p == 1)
        {
        printf("little endian\n");
        }
    else
        {
        printf("big endian\n");
        }

}

运行结果:

test.j[0] = 0xffffffef
test.j[1] = 0xffffffbe
test.j[2] = 0xffffffad
test.j[3] = 0xffffffde
little endian

    大小端存储问题,如果小端方式中(a 占至少两个字节的长度)则 a 所分配的内存最小地址那个字节中就存着1,其他字节是0.大端的话则1在 a 的最高地址字节处存放,char是一个字节,所以强制将char型量p指向a则p指向的一定是a的最低地址,那么就可以判断p中的值是不是1来确定是不是小端。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值