递归调用异步函数

递归调用异步函数,第1张

递归调用异步函数

问题是堆栈是否充满了调用,并可能在某些时候导致堆栈溢出?

否。 如果

asyncBar()
调用回调是异步传递的,则不会堆积堆栈。

在您的代码中:

function foo() {    asyncBar(foo);}

这是逐步发生的事情:

  1. 首先
    foo()
    被称为。
  2. 然后调用
    asyncBar(foo)
  3. 因为
    asyncBar
    是异步的,所以这意味着它将启动一个异步 *** 作(假设它是一个http GET,但是任何异步 *** 作都可以)。该异步 *** 作已启动,但随后
    asyncBar()
    立即返回。
  4. 最初的return调用
    foo()
    和堆栈已完全展开。
    foo()
    堆栈上再也没有了。
  5. 调用之后的任何代码将
    foo()
    继续运行,直到完成为止,并返回到事件循环。
  6. 同时,异步 *** 作将在将来的某个时间完成。这会将对您的回调的调用放在事件队列中。
  7. 当JS引擎执行完其他Javascript(这意味着堆栈完全为空)后,它将把该事件从事件队列中拉出并调用回调。
  8. 在这种情况下,回调函数就是
    foo
    这样,它将调用该函数并重新开始循环,直接回到步骤2。

没有堆栈堆积。关键是异步回调在当前堆栈完成之后的某个时候被调用,然后展开并返回系统。



欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/4960317.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-13
下一篇 2022-11-13

发表评论

登录后才能评论

评论列表(0条)

保存