当你在内存的栈中,存放了太多元素,就有可能在造成 stack overflow这个问题。
今天看看如何复现这个问题。
下图,是我写的程序,不断的创造1KB的栈,来看看执行了多少次,无限循环。
最后结果是7929kB时, 发生stack overflow. 通过ulimit,可以看到栈的理论最大数值(单位KB),基本一致。
其实我们可以更改stack的大小。如下图, ulimit -s 10000 修改为10000KB(近似10M)对应的,我们可以存储的栈的数据量也增加了。
这个例子想说明的是, 栈的存储空间很小,基于我的电脑,默认情况, 只能存储8192KB的数据,
对应的一张1280 * 720的图片载入到栈中,就会造成overflow!