【转】判断处理器是Big_endian的还是Little_endian的

首先说明一下Little_endian和Big_endian是怎么回事。

Little_endian模式的CPU对操作数的存放方式是从低字节到高字节,而Big_endian模式则是从高字节到低字节,比如32位的数0x12345678在两种模式下的存放如下:

Little_endian:

内存地址      存放内容

0x1000         0x78

0x1001         0x56

0x1002                           0x34

0x1003                           0x12

Big_endian:

内存地址      存放内容

0x1000           0x12

0x1001                           0x34

0x1002                           0x56

0x1003                           0x78

而联合体的存放顺序是所有成员都从地址值开始存放,于是可以通过联合体来判断。

#include <iostream>
using namespace std;

int CheckCPU()
{
    union
    {
        int a;
        char b;
    }c;
    c.a = 1;
    return (c.b == 1);
}

int main()
{    
    if (CheckCPU())
    {
        cout<<"Little_endian"<<endl;
    }
    else
    {
        cout<<"Big_endian"<<endl;
    }

    return 0;
}

分析:

在联合体中定义了两个成员int和char,而联合体的大小=sizeof(int) = 4,于是在内存中占四个字节的大小,假设占用的内存地址为:0x1000——0x1003,当给a赋值为1时,此时将根据是Little_endian还是Big_endian来决定存放的内存地址。

如果是Little_endian,则

内存地址      存放内容

0x1000        0x01

0x1001                          0x00

0x1002        0x00

0x1003                          0x00

又因为联合体的成员都从低地址存放,于是当取0x1000里面的内容作为b的值,取得的是0x01,即b=1,函数返回值为1,说明处理器是Little_endian。否则,则是Big_endian。

转自:http://blog.chinaunix.net/uid-25132162-id-1641532.html

时间: 2024-10-21 07:18:10

【转】判断处理器是Big_endian的还是Little_endian的的相关文章

Endian.BIG_ENDIAN和Endian.LITTLE_ENDIAN(http://smartblack.iteye.com/blog/1129097)

Endian.BIG_ENDIAN和Endian.LITTLE_ENDIAN 在ByteArray和Socket中,能看到一个属性endain. endian : String 更改或读取数据的字节顺序:Endian.BIG_ENDIAN 或 Endian.LITTLE_ENDIAN. 谈到字节序的问题,必然牵涉到两大CPU派系.那就是Motorola的PowerPC系列CPU和Intel的x86系列CPU.PowerPC系列采用big endian方式存储数据,而x86系列则采用little

Big_endian Little_endian

请写一个C函数,若处理器是Big_endian的,则返回0:若是Little_endian的,则返回1 int checkCPU( ) { { union w { int a; char b; } c; c.a = 1; return  (c.b ==1); } } 剖析:嵌入式系统开发者应该对Little-endian和Big-endian模式非常了解.采用Little-endian模式的CPU对操作数的存放方式是从低字节到高字节, Big-endian  模式的CPU对操作数的存放方式是从高

判断机器大端序和小端序

//若处理器是Big_endian的,则返回0:若是Little_endian的,则返回1 //联合体union的存放顺序是所有成员都从低地址开始存放 //一个联合变量的长度等于各成员中最长的长度. //应该说明的是,这里所谓的共享不是指把多个成员同时装入一个联合变量内, //而是指该联合变量可被赋予任一成员值,但每次只能赋一种值,赋入新值则冲去旧值. int checkCPU( ) { union w { int a; char b; } c; c.a = 1; return(c.b ==1)

编程判断大端字节序和小端字节序

代码一:联合体union的存放顺序是所有成员都从低地址开始存放,若处理器是Big_endian(从高字节到低字节存放数据)的,则返回0:若是Little_endian(从低字节到高字节存放数据)的,则返回1. int checkCPU() { union w { int a; char b; } c; c.a = 1; return (c.b == 1); } 代码二: #include <stdio.h> #include <stdlib.h> int main() { int

判断大小端序的C程序

概念 大端格式:字数据的高字节存储在低地址中,而字数据的低字节则存放在高地址中. 小端格式:与大端存储格式相反,在小端存储格式中,低地址中存放的是字数据的低字节,高地址存放的是字数据的高字节. 如5A6C中5A是高字节.6C是低字节,在大端序机器中,高字节位于低地址中,即在大端序中按照5A6C存储,在小端序中按照6C5A存储. 为什么存在这种模式 因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit.但是在C语言中除了8bit的char之外,还有16bit的

C/C++笔试忍法帖04——C/C++语法特性篇

1.Heap与stack的差别 Heap是堆,stack是栈. Stack的空间由操作系统自动分配/释放,Heap上的空间手动分配/释放. Stack空间有限,Heap是很大的自由存储区 C中的malloc函数分配的内存空间即在堆上,C++中对应的是new操作符. 程序在编译期对变量和函数分配内存都在栈上进行,且程序运行过程中函数调用时参数的传递也在栈上进行. 2.In C++, what does "explicit" mean? what does "protected&

c语言 union及 大端小端

union 关键字的用法与struct 的用法非常类似. union 维护足够的空间来置放多个数据成员中的"一种",而不是为每一个数据成员配置空间,在union 中所有的数据成员共用一个空间,同一时间只能储存其中一个数据成员,所有的数据成员具有相同的起始地址.例子如下: union StateMachine { char character; int number; char *str; double exp; }; **一个union 只配置一个足够大的空间以来容纳最大长度的数据成员

《C和C++程序员面试秘笈[精品]》-笔记

2015-12-16 原文:在C++中可以通过域操作符"::"来直接操作全局变量 2015-12-16 原文:后缀式(i++)必须返回对象的值,所以导致在大对象的时候产生了较大的复制开销,引起效率降低.因此处理使用者自定义类型(注意不是指内建类型)的时候,应该尽可能地使用前缀式递增/递减,因为它天生"体质"较佳. 2015-12-16 原文:内建数据类型的情况,效率没有区别. 自定义数据类型的情况,++i效率较高. 2015-12-16 原文:当表达式中存在有符号类

C语言面试题大汇总

C语言面试题大汇总 1.局部变量能否和全局变量重名? 答:能,局部会屏蔽全局.要用全局变量,需要使用"::" ;局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量.对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内. 2.如何引用一个已经定义过的全局变量? 答: extern 可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引