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

  • Post author:
  • Post category:其他




什么是大小端?

在这里插入图片描述

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


  • 大端模式:

    是指数据的

    高字节

    保存在内存的

    低地址

    中;

  • 小端模式:

    是指数据的

    高字节

    保存在内存的

    高地址

    中;

图示



如何判断大小端呢?



方法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.");
}

在这里插入图片描述



版权声明:本文为fly_wt原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。