通过代码判断当前机器的字节序

本文由jack分享,介绍了如何使用C语言判断计算机的字节序,包括小端和大端字节序的定义及优缺点,并给出了相关函数实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Hellow,我是jack,今天给大家分享的是C语言实现机器的字节序的判断。话不多说,让我们直接进入正题。

首先,让我们先介绍一下什么是字节序。

字节序,顾名思义,就是字节组织的顺序。我们可以将其根据其存储时从低位开始还是从高位开始分为两种,具体如下:

类型简写本质
大端BE(big endian)将高序字节存储在起始地址
小端LE(little endian)将低序字节存储在起始地址

两种字节序优缺点
小端优点:符合人的思维的字节序地址低位存储值的低位地址高位存储值的高位。从人的第一观感来说低位值小,就应该放在内存地址小的地方,也即内存地址低位;反之,高位值就应该放在内存地址大的地方,也即内存地址高位。

大端优点:直观的字节序地址,不要考虑对应关系只需要把内存地址从左到右按照由低到高的顺序写出,把值按照通常的高位到低位的顺序写出两者对照,一个字节一个字节的填充进去。
 

知道了这些,接下来就让我们来学习当前我们的面前的机器是小端还是大端存储。

//写代码判断当前机器的字节序
int chick_sys()
{
	int a = 1;
	char* p = (char*)&a;  //p相当于指向a中的地址的第一个占有位
	
    /*接着简单的判断p的值就可以判断机器的存储模式了
    if (p == 0) { return 1; }
	else
	{
	return 0;
	}*/
	return *p;     //同时可以直接返回p指针在主函数中判1接好了
}

 最后让我们把完整的函数补充完整。

//写代码判断当前机器的字节序
int chick_sys()
{
	int a = 111;
	char* p = (char*)&a;
	if (p == 0) { return 1; }
	else
	{
	return 0;
	}
	//return *p;
}
int main()
{
	int ret = chick_sys();
	if (ret = 1) { printf("小端"); }
	else printf("大端");
	return 0;
}

本章就和大家分享到这里,谢谢。

欢迎指正。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值