判断机器大小端的两种实现方法

 更新时间:2020年4月25日 17:48  点击:1595

第一种方法


思路:利用指针的强制类型转换

复制代码 代码如下:

#include <stdio.h>
int main(void)
{   
int data1 = 0x12345678;  
int i;  
for(i=0; i<4; i++) 
{      
printf("%#x ----->%p\n",*((char *)&data1 + i),(char *)&data1 + i);  
}    
return 0;
}

从输出的结果可以看出,高位地址0xbfc1b1ff存的是数据的高位0x12,低位地址0xbfc1b1fc存的是数据的低位0x78。所以是小端。同时我们亦可以看到,对数据data取地址实际指向的是存放低位数据的空间。

第二种方法

思路:利用共用体所有数据都从同一地址开始存储。

复制代码 代码如下:

#include <stdio.h>

int main(void)

{

    int i;

    union endian

    {

        int data;

        char ch;

    }test;

    test.data = 0x12345678;

    if(test.ch == 0x78)

    {

        printf("little endian!\n");

    }

    else

    {

        printf("big endian!\n");

    }

 

    for(i=0; i<4; i++)

    {

        printf("%#x ------- %p\n",*((char *)&test.data + i),(char *)&test.data + i);

    }

    return 0;

}

[!--infotagslink--]

相关文章

  • 关于大小端、位域的一些概念详解

    我们常用的x86结构都是小端模式,而大部分DSP,ARM也是小端模式,不过有些ARM是可以选择大小端模式。所以对于上面的maxHeight是应该以小端模式来存放,具体情况请看下面两表...2020-04-25
  • 节序问题:解析大小的端判定

    本篇文章是对大小的端判定进行了详细的分析介绍,需要的朋友参考下...2020-04-25
  • 判断机器大小端的两种实现方法

    第一种方法,思路:利用指针的强制类型转换。第二种方法,思路:利用共用体所有数据都从同一地址开始存储。...2020-04-25