C语言数据在内存中的存储经典面试题(一)

在这里插入图片描述
在这里插入图片描述

C语言数据在内存中的存储经典面试题(一)

题目:判断下面代码的运行结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

答案:

在这里插入图片描述
如果你做对了,那么恭喜大佬,这篇博客可能对你收益不大,全当复习数据在内存中的存储好了,这是专门针对编程小白初学数据在内存中的存储关于经典面试题的讲解,诚挚地希望能够到xdm。接下来我将开始我的讲解,手把手带xdm拿捏数据在内存中的存储经典面试题。

附1:

1、关于计算机底层计算原理的讲解:
计算机中的原码、反码、补码的讲解
2、关于看懂编译器是如何存储数据的:
数据大小端存储讲解
3、手把手带你拿捏计算机中的整形提升问题:
计算机中的整形提升讲解

附2:

1、由于C语言标准并没有规定char类型默认是属于unsigned char类型还是signed char类型,所以char是属于那个类型是需要根据编译器来确定的,然后在一般情况下,大多数的编译器把char类型归于signed char类型,楼主的这个编译器就是归于signed char类型,若你的编译器规定char类型是unsigned char类型,那么计算出来的结果是跟我不一样的,具体结果跟编译器有关,只有相对的答案,没有绝对的答案。
2、但是在C语言标准中,是明确规定了int类型是属于signed int类型中的,所以这里算出来的结果若跟我不一样,就是你自己的原因了。
3、int类型所占内存空间是4个字节,一个字节是8个比特位;char类型所占空间是1个字节,一个字节同样也是8个比特位。所以在计算机内存中存储的二进制序列会发生整形截断和整形提升的现象。

问题解析:

1、在开始我的讲解之前,你必须得具备上述附1的三个知识点才能听得懂,如果不理解那三个知识点的,这边建议你先看我上面的两篇关于这三个知识点的讲解,非常地详细,手把手带你拿捏这三个知识点。
2、接下来,我将要用代码演示的方式来为大家讲解此题。

代码演示:

在这里插入图片描述

3个变量的随机初始化,其中内存1代表a变量,内存2代表b变量,内存3代表c变量
在这里插入图片描述
3个变量指定初始化后的值

在这里插入图片描述

演示代码提取:

#define _CRT_SECURE_NO_WARNINGS 1

#include <stdio.h>

int main()
{
	char a = -1;
	signed char b = -1;
	unsigned char c = -1;
	printf("a=%d,b=%d,c=%d\n", a, b, c);
	return 0;
}

//由于C语言标准并没有规定char类型是属于unsigned char类型还是signed char类型,所以char是属于那个类型是需要根据编译器来确定的
//在一般情况下,大多数的编译器把char类型归于signed char类型,楼主的这个编译器就是归于signed char类型
//若你的编译器规定char类型是unsigned char类型,那么计算出来的结果是跟我不一样的,具体结果跟编译器有关,只有相对的答案,没有绝对的答案

//但是在C语言标准中,是明确规定了int类型是属于signed int类型中的,所以这里算出来的结果若跟我不一样,就是你自己的原因了

//int类型的时候
//10000000000000000000000000000001(-1的原码)
//11111111111111111111111111111110(-1的反码)
//11111111111111111111111111111111(-1的补码)

//char类型的时候,发生整形截断
//11111111(未被整形提升前)
//11111111111111111111111111111111(有符号整形提升后)
//00000000000000000000000011111111(无符号整形提升后)


备注:

楼主不才,不喜勿喷,若有错误或需要改进的地方,非常感谢你的指出,我会积极学习采纳。谢谢家人们一直以来的支持和鼓励,我会继续努力再接再励创作出更多优质的文章来回报家人们的。编程爱好的xdm,若有编程学习方面的问题可以私信我一同探讨(我尽力帮),毕竟“众人拾柴火焰高”,大家一起交流学习,共同进步!

在这里插入图片描述

2022年1月4日

  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

曜摆摆

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

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

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

打赏作者

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

抵扣说明:

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

余额充值