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

时间:2021-05-19

第一种方法


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

复制代码 代码如下:
#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;

}

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章