函数调用的时候为什么会出现栈溢出(带你理解stackoverflow背后的相关原理)

今天,大川和小川再次见面,他们开始交谈起来:

image-20250516154826537

计算机组成原理作为408里面的难度的天花板,虽然这个分数不是最多的,但是对于很多的考研学子都觉得苦不堪言,尤其是对于软件工程这个专业的学生而言,因为这个专业的学生对于软件的接触很多,但是对于硬件的了解很少,对于汇编语言,编译原理,数字电路这些课程都是没有接触的,因此这个学习的过程就显得非常的吃力;

今天我们会从函数的调用开始引入,逐步的了解这个过程,弄清楚为什么会出现栈溢出,背后的原理是什么;

image-20250516155518849

栈溢出的英文名字叫做stackoverflow,stack就是我们的数据结构与算法这门课程里面学习的这个栈这个数据结构,基本的规则就是后进先出,overflow就是溢出的意思,互联网上面有一个非常大的编程交流社区就是使用的这个名字作为该社区的名字,不知道大家听说过没有;

image-20250516160005563

下面的这个是关于这个代码的汇编结果,通过这个,可以帮助我们进行这个底层的更好的理解:

image-20250516160323742

我们在学习这个C语言的时候一定听说过一句经典的话,就是形参的修改是不会影响实参的,形参是实参的临时拷贝,这个主要的原因就是我们的main函数调用新的自定义函数的时候,创建了新的函数栈帧,因此我们的实参的具体的数值就会被拷贝一份,交给,放到我们的新的函数栈帧里面去了;

所以,这个过程实际上形参的修改是不会影响我们的实参的,因为他们在我们的函数栈帧里面的区域不一样,归属的栈帧也不是同一个,两个函数有自己独立的栈帧,形参和实参在各自的函数栈帧里面,所以这个形参的修改只会影响调用的自定义函数的栈帧里面的情况,对于我们的主函数这个函数栈帧里面的实参的具体数值大小是完全没有任何的这个影响的;

image-20250516161800660

我们通过下面的这个例子,理解一下这个过程:

image-20250516162154729

image-20250516162230278

看到这里,我们就需要提一下这个栈溢出了,怎么说呢,就是我们上面的例子是只有一个 函数的调用,如果是A调用B,B调用C,C调用D,这样的连续的调用,是不是需要把每一次需要执行的下一个指令的地址记录下来;

所以这个时候就从我们的内容里面单独划分一个下的区域作为栈区,专门去存放这个下一个指令的地址;

image-20250516162706805

接下来,他们聊到了合格内联函数的相关的内容,感兴趣的同学可以了解一下,也是性能优化的一个方面:

image-20250516163501199

内联函数具体优化了什么,具体是如何进行这个相关的操作的:

image-20250516163529207

什么样的函数适合作为内联函数,什么样的函数不适合作为内联函数:

image-20250516163601056

image-20250516163613695

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值