【C语言】【百度笔试】写一个代码判断当前机器的字节序(大小端)

1.代码实现:

#include<stdio.h>
int check()
{
	int i= 1;
	return (*(char*)&i);
}
int main()
{
	int ret = check();
	if (ret == 1)
		printf("小端\n");
	else
		printf("大端\n");
	return 0;
}

思路:
整型 1 在内存中:
大端:00 00 00 01
小端:01 00 00 00
所以判断大小端只需要把内存中第一个字节的内容拿出来看是 1 还是 0

取出逻辑:

(*(char*)&i)

先取出 i 的地址,将其强制类型转换为 char*时在低地址位置截断,取出了第一个字节的地址,然后再解应用,下面判断第一个字节是 1 还是 0 即可

2.什么是大小端:

大端:数据的高位字节内容保存到低地址处
小端:数据的低位字节内容保存到低地址处

以整型 1 为例:int 类型占 4 个字节:00 00 00 01 从左到右字节是高位到低位,而地址是从左到右,低位到高位
即:
整型 1 在内存中:
大端:00 00 00 01
小端:01 00 00 00

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值