JavaScript Async/Await logic behaving as synchronous(作为同步行为的JavaScript Async/AWait逻辑)
问题描述
如果我理解正确的话,使用关键字async声明的函数应该返回承诺。在async3函数的情况下,我们有10亿次迭代,这使得返回值花费的时间稍长一些。分析下面的代码,我预计会发生的情况是,通过调用sync1和sync2函数,立即登录控制台,稍后将出现async3函数日志。但是,我注意到的是,sync1和sync2函数仅在async3结束后登录。async3函数不应该运行在另一个线程上或事件循环外部,而不会阻止在运行时调用的其他函数的执行吗? 数据-lang="js"数据-隐藏="假"数据-控制台="真"数据-巴贝尔="假">
function sync1() {
console.log(1);
}
function sync2() {
console.log(2);
}
async function async3() {
let iteration = 0;
let number = 0;
while (iteration <= 1000000000) {
number = iteration;
iteration++;
}
return number;
}
sync1();
sync2();
async3().then((val) => console.log(val));
你能澄清它为什么会这样做吗?我错过了什么?
我所期望的:
sync1(); // console logged immediately
sync2(); // console logged immediately
async3().then((val) => console.log(val)); // console logged moments later
当前情况:
sync1(); // console logged after async3 is done sync2(); // console logged after async3 is done async3().then((val) => console.log(val)); // console logged after async3 is done
推荐答案
记住,基本上是单线程的。
虽然async3
是异步的,但它的操作是完全同步的,并且占用大量的CPU。只有当浏览器有一点空闲时间时,输出才会(可视地)打印到控制台,但以下块:
while (iteration <= 1000000000) {
number = iteration;
iteration++;
}
在上述计算完成之前,浏览器没有空闲时间。
对于sync1
和sync2
要立即记录,一种解决方案是让async3
每100,000次(或更多)暂停一次,并等待setTimeout
,从而使浏览器有机会执行诸如向控制台显示内容、处理其他事件侦听器、呈现更改等操作。
另一种解决方案是在工作器中执行计算繁重的async3
函数,该函数位于单独的线程上,不会阻塞浏览器的主线程。
这篇关于作为同步行为的JavaScript Async/AWait逻辑的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:作为同步行为的JavaScript Async/AWait逻辑
基础教程推荐
- 我什么时候应该在导入时使用方括号 2022-01-01
- 有没有办法使用OpenLayers更改OpenStreetMap中某些要素 2022-09-06
- 动态更新多个选择框 2022-01-01
- 当用户滚动离开时如何暂停 youtube 嵌入 2022-01-01
- Karma-Jasmine:如何正确监视 Modal? 2022-01-01
- 在for循环中使用setTimeout 2022-01-01
- 悬停时滑动输入并停留几秒钟 2022-01-01
- 响应更改 div 大小保持纵横比 2022-01-01
- 在 JS 中获取客户端时区(不是 GMT 偏移量) 2022-01-01
- 角度Apollo设置WatchQuery结果为可用变量 2022-01-01