今天图老师小编要向大家分享个判断机器大小端的两种实现方法教程,过程简单易学,相信聪明的你一定能轻松get!
【 tulaoshi.com - 编程语言 】
第一种方法
思路:利用指针的强制类型转换
代码如下:
#include stdio.h
int main(void)
{
int data1 = 0x12345678;
int i;
for(i=0; i4; i++)
{
printf("%#x -----%pn",*((char *)&data1 + i),(char *)&data1 + i);
}
return 0;
}
从输出的结果可以看出,高位地址0xbfc1b1ff存的是数据的高位0x12,低位地址0xbfc1b1fc存的是数据的低位0x78。所以是小端。同时我们亦可以看到,对数据data取地址实际指向的是存放低位数据的空间。
第二种方法
思路:利用共用体所有数据都从同一地址开始存储。
代码如下:
#include stdio.h
int main(void)
{
(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)int i;
union endian
{
(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)int data;
char ch;
}test;
test.data = 0x12345678;
if(test.ch == 0x78)
{
(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)printf("little endian!n");
}
else
{
(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)printf("big endian!n");
}
for(i=0; i4; i++)
{
(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)printf("%#x ------- %pn",*((char *)&test.data + i),(char *)&test.data + i);
}
return 0;
}
来源:http://www.tulaoshi.com/n/20160219/1596485.html
看过《判断机器大小端的两种实现方法》的人还看了以下文章 更多>>