手机
当前位置:查字典教程网 >编程开发 >C语言 >判断机器大小端的两种实现方法
判断机器大小端的两种实现方法
摘要:第一种方法思路:利用指针的强制类型转换复制代码代码如下:#includeintmain(void){intdata1=0x12345678;...

第一种方法

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

复制代码 代码如下:

#include <stdio.h>

int main(void)

{

int data1 = 0x12345678;

int i;

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

{

printf("%#x ----->%pn",*((char *)&data1 + i),(char *)&data1 + i);

}

return 0;

}

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

从输出的结果可以看出,高位地址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 ------- %pn",*((char *)&test.data + i),(char *)&test.data + i);

}

return 0;

}

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

【判断机器大小端的两种实现方法】相关文章:

深入探讨Linux静态库与动态库的详解(一看就懂)

C语言解线性方程的四种方法

C语言中判断int,long型等变量是否赋值的方法详解

深入C中常用的三种排序方法总结以及探讨分析

Linux C 获取进程退出值的实现代码

在vs2010中,输出当前文件路径与源文件当前行号的解决方法

C++输入一个字符串,把其中的字符按照逆序输出的两种方法解析

c语言求1+2+...+n的解决方法

C++求斐波那契数的实例代码

求子数组最大和的实例代码

精品推荐
分类导航