用C语言代码判别CPU的大小端模式

   Big-endian和little-endian是描述排列存储在计算机内存里的字节序列的术语。
      Big-endian是一种大值的一端(序列中更典型值)存在前面(在最小的存储地址)的顺序。Little-endian是一种小值的一端(序列中较不典型的值)存储在前的顺序。比如,在Big-endian的电脑中,需要两个字节把十六位数4F52当作4F52存在存储器中(如果4F存在存储地址1000中,比如说,52将存在1001中)。在little-endian系统里,将被存为524F(52存在存储地址1000中,比如说,4F将存在1001中)。

一个例子:
如果我们将0x1234abcd写入到以0x0000开始的内存中,则结果为
           big-endian   little-endian
0x0000      0x12        0xcd
0x0001      0x34        0xab
0x0002      0xab        0x34
0x0003      0xcd        0x12

那么,怎么用C语言来实现判别功能呢?

有两种方法,第一种借用指针和强制转换的方法来实现。

代码如下:

 

 

   1:  define TRUE 1
   2:  #define FALSE 0
   3:  #define BOOL int
   4:   
   5:  BOOL  isBigEndian()
   6:  {
   7:      int  i = 1;   /* i = 0x00000001*/
   8:      char  c = *(char  *)&i; /* 注意不能写成 char c = (char)i; */
   9:      return  (int )c != i;
  10:  }
 

如果是little endian字节序的话,那个i = 1;的内存从小到大依次放的是:0x01 0x00 0x00 0x00,如是,按照i的起始地址变成按照char *方式(1字节)存取,即得c = 0x01;
反之亦然

第二种呢,借用c语言中union这种数据类型。

   1:  BOOL  isBigEndian()
   2:  {
   3:      union
   4:      {
   5:          int  i;
   6:          char  c;
   7:      }test;
   8:      
   9:      test.c = 2;
  10:   
  11:      return  test.i != 2;
  12:  }

 

这里用的是union来控制这个共享布局,有个知识点就是union里面的成员c和i都是从低地址开始对齐的。同样可以得到如此结果,而且不用转换,清晰一些。

参考:http://blog.csdn.net/jiangnanyouzi/article/details/3158702

以及 http://blog.csdn.net/flickedball/article/details/4096991

posted on 2013-10-11 15:41  苯苯吹雪  阅读(2754)  评论(0编辑  收藏  举报

导航