0
点赞
收藏
分享

微信扫一扫

如何判断大小端?(C语言实现)


什么是大小端?

如何判断大小端?(C语言实现)_大小端

"endian"一词出自茨威格的讽刺小说《格列夫游记》。小人国的内战源于吃鸡蛋时究竟是从大头(Big-Endian)敲开还是从小头(Little-Endian)敲开,由此曾发生过6次叛乱,其中一个皇帝送了命,另一个丢了王位。

  • 大端模式:是指数据的高字节保存在内存的低地址中;
  • 小端模式:是指数据的高字节保存在内存的高地址中;

如何判断大小端?(C语言实现)_数据_02

如何判断大小端呢?

方法1:利用联合体

关键点:联合体的存放顺序是所有成员都从低地址开始存放。

void check_cup(void)
{
union{
short s;
char c[sizeof(short)];
}un;

un.s = 0x0102;
if (un.c[0] == 1 && un.c[0] == 2)
puts("Big endian.");
else if (un.c[0] == 2 && un.c[0] == 1)
puts("Little endian.");
else
puts("Unkown");
}

方法2:利用强制类型转换

void check_cup(void)
{
int a = 0x0102;
char *p = (char *)&a;
if (*p == 2)
puts("Big endian.");
else if (*p == 1)
puts("Little endian.");
}

如何判断大小端?(C语言实现)_嵌入式_03


举报

相关推荐

0 条评论