我有以下代码示例来说明我的观点。当我在 Vista 上的 IE8 中加载它时,我收到错误“Stack Overfow at line:16”
如果我使用顶级函数(在 testClass 对象之外)进行递归,我可以递归数百万次而不会出现堆栈溢出。
为什么会这样?最终我只是实现了一个函数队列而不是使用递归,但对我来说没有意义,我想了解原因。
- 代码 -
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN">
<html>
<head>
<title>Recusion Test</title>
<body>
</body>
<script type="text/javascript">
function testClass() {
this.x = 15;
this.recurse = function() {
this.x--;
this.recurse();
}
}
var wtf = new testClass();
wtf.recurse();
alert('done');
</script>
</head>
</html>