c语言实现之得到当前机器的字节序是大端还是小端(多种方法实现)

大、小端

首先,先介绍一下大小端的概念。

大端字节序存储模式:数据的低位存在内存的高地址中,高位存在低地址中。

小端字节序存储模式:数据的低位存在内存的低地址中,高位存在高地址中。

这里举个例子。譬如我们要存储a=0x11223344(44是较低位),这个整形数字。若按小端存储模式,假设在这里从前到后是从低地址到高地址。则应该是11 22 33 44这样子存储,大端则是44 33 22 11存储。

大家应该了解了吧。

实现方法一

首先,我们可以先初始化一个变量为1,其16进制表达为0x00000001,01是低位。若按小端,则取出来的第一个是1,大端则是0。所以,我们可以取出第一个字节的字符。我们可以用指针来接受1这个变量的地址,因为我们只想访问第一个字节,所以记得强制类型转换成char*类型的指针。

代码如下:

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int check_sys()
{
	int a = 1;
	return *(char*)&a;
}
int main()
{
	int ret = check_sys();
	if (1 == ret)
	{
		printf("小端字节序存储模式\n");
	}
	else
	{
		printf("大端字节序存储模式\n");
	}
	return 0;
}

当然,在这里也可以用其他数来证明,只是1更简单明了。

实现方法二

这里,我们还是会用1.只是这种方法我们会用到联合体。我们知道联合体也叫共用体,一个联合变量他们是共用一块空间的。

所以,我们可以定义一个联合体变量。里面可以有两个成员,第一个成员为char类型,第二个为整形。然后初始化第二个变量为1 ,再看第一个char类型的变量为几。若为1,则是1小端,反之大端。

代码如下:

#include <stdio.h>
int check_sys()
{
	union un//这里也可以匿名联合体,因为只会用这一次
	{
		char c;
	int b;
	}u;
	u.b = 1;
	return u.c;
}
int main()
{
	int ret = check_sys();
	if (1 == ret)
	{
		printf("小端字节序存储模式\n");
	}
	else
	{
		printf("大端字节序存储模式\n");
	}
	return 0;
}

 

好了,我要介绍的两种方法介绍完了,大家还有什么其他的方法,欢迎评论或私信

祝:“码”思泉涌,下“指”如有神。 

  • 16
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值