Might a promise be garbage collected too early without a .then() in JavaScript(在没有.Then()的情况下,承诺是否会过早地被垃圾回收)
问题描述
所以基本上我希望异步执行两个同步承诺。如下所示:
(function foo() {
var newValues = ...;
this.getMessages().then((msgs: Array<any>) => {
this.saveMessages(msgs.concat(newValues));
});
})()
现在,因为我不想等待saveMessages完成执行,所以我没有在末尾添加一个.then()。因为我不在乎结果。我只想执行异步函数,以便在某个时刻使消息脱机。
但我担心承诺可能会被垃圾收集,因为按照标准(据我所知),承诺总是需要.then。
所以我的问题是,我是否需要添加一个空的.then,以确保它不会过早地被垃圾收集,并且函数不会正确执行。像这样:this.saveMessages(msgs.concat(newValues)).then();?
在浏览器和NodeJS中是否相同?
推荐答案
否,Promise在到达之前不知道您如何处理它的完成。
您不需要担心先发制人地进行垃圾回收,但您确实需要担心全局执行上下文在承诺解析之前完成(如关闭连接),这将取消承诺并执行垃圾收集。由于您是在异步运行它,如果您想要确保程序等待承诺的完成而不使一切同步,您可以始终保持作用域变量上的承诺的完成状态或使用事件发射器...
var imDone = false;
function foo() {
var newValues = ...;
this.getMessages().then((msgs: Array<any>) => {
this.saveMessages(msgs.concat(newValues))
.catch(err=> { console.log(err); imDone = true; })
.then(()=> imDone = true);
}).catch(err=> console.log(err));
}
....
if (imDone) {
// finish execution, res.send() or res.end() in Node
}
这篇关于在没有.Then()的情况下,承诺是否会过早地被垃圾回收的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在没有.Then()的情况下,承诺是否会过早地被垃圾回收
基础教程推荐
- 即使每次插入第一个输入的值不同,第二个输入仍显示相同的输入值 2022-01-01
- CORS:当凭据标志为真时,无法在 Access-Control-Allow-Origin 中使用通配符 2022-01-01
- 最佳动态 JavaScript/JQuery 网格 2022-01-01
- HTML5 画布调整为父级 2022-01-01
- 当木偶师打开Chrome时,不能使用Chrome扩展 2022-01-01
- 使用 jQuery 在悬停时交换 DIV 类 2022-01-01
- 带角度的选项卡:仅使用 $http 在单击时加载选项卡 2022-01-01
- 从快速中间件中排除路由 2022-01-01
- 逻辑运算符 ||在 javascript 中,0 代表 Boolean false? 2022-01-01
- 在 Javascript 中使用 Fetch API 上传文件并显示进度 2022-01-01
