深入理解计算机的大端存储和小端存储

本文介绍了大端模式和小端模式的概念,这两种模式在计算机内存中处理多字节数据的方式不同。大端模式将高位字节存储在低地址,而小端模式则相反。大小端模式的存在源于处理器如何组织多个字节的数据。通过一个简单的C程序示例,展示了如何判断系统是采用大端还是小端模式。
摘要由CSDN通过智能技术生成

目录

1.什么是大端和小端

2.为什么会有大小端模式的区分

3. 例题


我们在开始可以先看这样一个故事

有两个特别强大的国家在过去进行了36个月的战争,在这期间发生了件事情,就是吃鸡蛋的时候,原始的方法是打破鸡蛋较大的一端,可那时的皇帝的祖父由于小时侯吃鸡蛋,按这种方法把手指弄破了,因此他的父亲,就下令,命令所有的子民吃鸡蛋的时候,必须先打破鸡蛋较小的一端,违令者重罚。然后老百姓对此法令极为反感,期间发生了多次叛乱,其中一个皇帝因此送命,另一个丢了王位,产生叛乱的原因就是另一个国家Blefuscu的国王大臣煽动起来的,叛乱平息后,就逃到这个帝国避难。据估计,先后几次有11000余人情愿死也不肯去打破鸡蛋较小的端吃鸡蛋。这个其实讽刺当时英国和法国之间持续的冲突。Danny Cohen一位网络协议的开创者,第一次使用这两个术语指代字节顺序,后来就被大家广泛接受,这个就是关于大端小端名词的由来。

1.什么是大端和小端

大端模式:就是高位字节排放在内存的低地址端,低位字节排放在内存的高地址端。

(其实,大端模式才是我们直观上认为的模式,但实际并不是这样)

小端模式:就是低字节排放在内存的低地址端,高位字节排放在内存的高地址端。

也就是这样的

  

下面我们看个例子

我们在VS环境下,进行深入分析:

数据本来在内存中存储是由高地址到低地址的 ,但我们在VS中看它是由高字节序到低字节序存储的,也就是小端存储,所以我们可以认为VS是小端存储模式 

2.为什么会有大小端模式的区分

这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8 bit的char之外,还有16 bit的short型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。

3. 例题

百度在2015年系工程师笔试题中就让设计一个程序来判断当前机器的字长

先写主函数

int main()
{
	int ret = check_sys();
	if (ret == 1)
	{
		printf("小端\n");
	}
	else
	{
		printf("大端\n");
	}
	return 0;
}

 如果check_sys()函数返回1,那就是小端存储,若返回0,就是大端存储

int check_sys()
{
	int a = 1;
	char* p = (char*)&a;

	if (*p == 1)
	{
		return 1;//小端
	}
	else
	{
		return 0;//大端
	}
}

我们也可以精简代码(不用if来判断,直接return 把*p 返回)

int check_sys()
{
	int a = 1;
	char* p = (char*)&a;
	return *p;
}

还可以继续精简代码(不用创建临时变量p,直接return把&a返回 )

int check_sys()
{
	int a = 1;
	return *(char*)&a;
}

代码合起来就是

int check_sys()
{
	int a = 1;
	return *(char*)&a;
}
int main()
{
	int ret = check_sys();
	if (ret == 1)
	{
		printf("小端\n");
	}
	else
	{
		printf("大端\n");
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

快到锅里来呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值