stack overflow复现

作者 : admin 本文共307个字,预计阅读时间需要1分钟 发布时间: 2024-06-9 共2人阅读

当你在内存的栈中,存放了太多元素,就有可能在造成 stack overflow这个问题。 

今天看看如何复现这个问题。

下图,是我写的程序,不断的创造1KB的栈,来看看执行了多少次,无限循环。

stack overflow复现插图

最后结果是7929kB时, 发生stack overflow. 通过ulimit,可以看到栈的理论最大数值(单位KB),基本一致。

stack overflow复现插图(1)

其实我们可以更改stack的大小。如下图, ulimit -s 10000 修改为10000KB(近似10M)对应的,我们可以存储的栈的数据量也增加了。

stack overflow复现插图(2)

这个例子想说明的是, 栈的存储空间很小,基于我的电脑,默认情况, 只能存储8192KB的数据,

对应的一张1280 * 720的图片载入到栈中,就会造成overflow!

本站无任何商业行为
个人在线分享 » stack overflow复现
E-->