转载:大端和小端

简介:

大端和小端

    嵌入式开发者应该对大端和小端很熟悉。在内存单元中数据是以字节为存储单位的,对于多字节数据,在小端模式中,低字节数据存放在低地址单元,而在大端模式 中,低字节数据存放在高地址单元。比如一个定义一个short型的变量a,赋值为1,由于short型数据占2字节。

在小端模式中,其存放方式为

0X4000  00000001

0X4001  00000000

而在大端模式中,其存放方式为

0X4000  00000000

0X4001  00000001

若需用程序验证系统是大端模式还是小端模式(一般我们用的x86结构的都是小端模式),有两种方法

1.利用联合体的性质

    因为联合体中的成员是共享内存的,并且数据是从低地址存放的,可以利用这一性质判断。

复制代码
复制代码
typedef union 
{
    char a;
    short c;
}U;

int checkCPU1()  //若是小端则返回1,否则返回0 
{
    U u;
    u.c=1;
    //printf("%d\n",u.a);
    return u.a==1;
}
复制代码
复制代码

由于short占2字节,而char占1字节,当对c赋值为1时,若系统为小端模式,则在系统中存放方式为:

000000001

000000000

那么当取a的值时,a的整型值必定为1;否则为0.

2.强制取低地址单元的数据

复制代码
复制代码
int checkCPU2()
{
    short a=0x1234;
    char *p=(char *)&a;
    //printf("%d\n",*p);
    return *p==0x34;    
} 
复制代码
复制代码

很显然,若是小端模式,指针p指向的单元里面的数据整型值必为0x34,否则为0x12。

测试程序:

复制代码
复制代码
/*测试系统大端模式/小端模式 2011.10.1*/ 

#include <iostream>
using namespace std;

typedef union 
{
    char a;
    short c;
}U;

int checkCPU1()  //若是小端则返回1,否则返回0 
{
    U u;
    u.c=1;
    //printf("%d\n",u.a);
    return u.a==1;
}

int checkCPU2()
{
    short a=0x1234;
    char *p=(char *)&a;
    //printf("%d\n",*p);
    return *p==0x34;    
} 

int main(int argc, char *argv[])
{
    printf("%d\n",checkCPU1());
    printf("%d\n",checkCPU2());
    return 0;
}
复制代码
复制代码




目录
相关文章
|
4月前
|
存储
计算机存储,字节分为大端和小端
计算机存储,字节分为大端和小端
35 1
|
3月前
|
存储 网络协议 API
大端与小端概念、多字节之间与单字节多部分的大小端转换详解
大端与小端概念、多字节之间与单字节多部分的大小端转换详解
62 1
|
7月前
|
存储 C语言
大端存储和小端存储
1.大小端字节序 2.大端存储 3.小端存储 4.为什么会有大小端存储模式之分? 5.如何判断当前机器是大端存储还是小端存储 方法1 方法2
1803 0
|
7月前
|
存储
大端法与小段法的区别
大端法与小段法的区别
96 0
|
8月前
|
存储 编译器 C语言
大小端字节序和整型提升
大小端字节序和整型提升
|
10月前
|
存储 编译器 C语言
【大小端问题】
大小端是什么? 计算机在内存存储中有两中存储模式: 大端字节序存储模式和小端字节序存储模式。 大端存储模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中。 小端存储模式,是指数据的低位保存在内存的低地址中,而数据的高位,保存在内存的高地址中。
|
存储 编译器 C语言
|
存储 小程序 编译器
大小端字节序详解
在开始正文之前,我想先问一下大家,内存中是怎样存放一个数的?当然啊,我这里问的不是数据存储的形式(比如整数存原码,负数存补码),而是一个数据存放的顺序 我们先看下面这个例子,当我们看看当把十六进制函数0x11223344存进内存中会是怎么样的。
大小端字节序详解
大端和小端模式
大端和小端模式

热门文章

最新文章