递归代码在数组列表偏大的情况下会导致堆栈溢出。一个解决办法

Posted 来亦何哀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了递归代码在数组列表偏大的情况下会导致堆栈溢出。一个解决办法相关的知识,希望对你有一定的参考价值。

var list = readHugeList();

var nextListItem = function() {
    var item = list.pop();

    if (item) {
        // process the list item...
        nextListItem();
    }
};

潜在的堆栈溢出可以通过修改nextListItem 函数避免:
var list = readHugeList();

var nextListItem = function() {
    var item = list.pop();

    if (item) {
        // process the list item...
        setTimeout( nextListItem, 0);
    }
};
堆栈溢出之所以会被消除,是因为事件循环操纵了递归,而不是调用堆栈。当 nextListItem 运行时,如果 item不为空,timeout函数(nextListItem)就会被推到事件队列,该函数退出,因此就清空调用堆栈。当事件队列运行其timeout事件,且进行到下一个 item 时,定时器被设置为再次调用 nextListItem。因此,该方法从头到尾都没有直接的递归调用,所以无论迭代次数的多少,调用堆栈保持清空的状态。

以上是关于递归代码在数组列表偏大的情况下会导致堆栈溢出。一个解决办法的主要内容,如果未能解决你的问题,请参考以下文章

使用 setTimeout 避免堆栈溢出

Java如何在不使用递归的情况下导致栈溢出?

由于递归方法调用导致 Java 堆栈溢出

如果不允许 LP 递归,那么可能会出现堆栈溢出的情况?

堆栈溢出一般是由啥原因导致的?

x64 汇编中的递归阶乘子例程导致堆栈溢出