let p = new Promise(resolve => {})
const noReturn = async function() {
const res = await p()
return res
}
某处多次调用noReturn
方法,会不会有什么不好的影响?
let p = new Promise(resolve => {})
const noReturn = async function() {
const res = await p()
return res
}
某处多次调用noReturn
方法,会不会有什么不好的影响?
10 回答11.3k 阅读
5 回答4.9k 阅读✓ 已解决
4 回答3.2k 阅读✓ 已解决
2 回答2.8k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
3 回答2.2k 阅读✓ 已解决
2 回答2.6k 阅读✓ 已解决
p
到底是Promise
,还是是函数?如果p
是Promise
,会有不好的影响,否则不会。当前V8的Promise的实现,会在满足以下条件的时候回收掉所有
.then
链的上下文:所以以下代码完全没有问题,所有东西都会被正确回收
上面的代码中,1和2满足,因为没有变量存着那个空
Promise
,所以3也满足,所以async
内的所有上下文都被释放,collectable
只剩下了空壳Monad,薛定谔的猫早跑掉了。而这段代码会造成内存泄漏
上面的代码会造成内存泄漏,只有
deadPromise = null
之后才能回收。一点后话,我猜题主也是在想,如果我们没有
AbortablePromise
,那我们至少能明确标示出一个Promise可以被垃圾回收吧?幸运的是,我们可以,但是要用到上面这样的hack。不过,现在我们有
AbortController
了,说明社区已经基本上对AbortablePromise
怎么实现有了共识:应该throw出去。这样的话,我们就不应该用这样的hack了,而应该与fetch
它们保持一致。