c语言 之大端小端存储问题

我们都知道数据在计算机中的存储是以补码形式存储的。在计算机中,如果数据的高字节内容放在高地址处低字节内容放在低地址处,我们称它为小端字节序;相反,如果数据的高字节内容放在底地址处,低字节内容放在高地址处,我们称它为大端字节序。

例如: int n=1;

它的原码,反码,补码都是 00000000 00000000 00000000 00000001

它在计算机中的小端存储字节序为  00 00 00 01

                          大端存储字节序为 01 00 00 00

但是我们怎么知道一个数在计算机中是以大端字节序列存储还是小端字节序存储的呢?下面我给出两种方法来求出数据在计算机中的存储方式,代码如下:

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


除了这种方式,我们还可以用共用体的方式解决这个问题

代码如下:

#include <stdio.h>
union UN
{
	char c;
	int i;
}un;
int main()
{
	un.i = 1;
	if (un.c ==0)
		printf("小端\n");
	else 
		printf("大端\n");
	system("pause");
	return 0;
}






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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值