Chinaunix首页 | 论坛 | 博客
  • 博客访问: 226314
  • 博文数量: 88
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 555
  • 用 户 组: 普通用户
  • 注册时间: 2013-09-03 13:08
个人简介

失意高调,得意低调

文章分类

全部博文(88)

文章存档

2021年(3)

2020年(2)

2018年(2)

2017年(3)

2016年(6)

2015年(19)

2014年(32)

2013年(21)

我的朋友

分类: LINUX

2013-09-11 15:33:32

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


内存地址

0x4000

0x4001

存放内容

0x34

0x12


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


内存地址

0x4000

0x4001

存放内容

0x12

0x34

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

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

#include

void main()
{
    int a = 0x01;
    char * p = (char*) & a;
    if(*p == 1)
        {
        printf("little endian\n");
        }
    else
        {
        printf("big endian\n");
        }
}

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

阅读(1501) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~