您好,匿名用户

如何从程序执行时间体现async的异步性

0 投票

1.为了测试async的异步性能,写了如下代码(可直接在浏览器console或node上运行)

async function maptest(item) {
    console.time('x'+item);
    console.log(item);
    for(let i = 0; i< 100000; i++) {
        let name = "test";
    }
    console.timeEnd('x'+item);
    return 1;
}

var list = [1,2,3,4,5,6,7,8,9,0];

console.time('xall');
for(var i = 0; i < 10; i++)
{
    maptest(list[i]).then();
}
console.timeEnd('xall');

输出结果为:

1
x1: 1.18212890625ms
2
x2: 0.097900390625ms
3
x3: 0.0830078125ms
4
x4: 0.078857421875ms
5
x5: 0.078857421875ms
6
x6: 0.080078125ms
7
x7: 0.080078125ms
8
x8: 0.079833984375ms
9
x9: 0.0810546875ms
0
x0: 0.0791015625ms
xall: 3.309814453125ms
1.182+0.098+0.083+0.079+0.079+0.080+0.080+0.080+0.081+0.079=1.921 < 3.3

问:从执行时间来看,总执行耗时并不是最长的一次maptest执行耗时,反而是比所有maptest函数执行时间之和还长。async不是异步执行的吗,此处为何体现不出async的异步性能?另外,为什么x1的执行时间远远大于其他时间?

用户头像 提问 5月22日 @ Twitch 中士 (1,300 威望)
分享到:

1个回答

0 投票
 
最佳答案

JS线程始终只有一个。xall也不是执行的时间,只是返回的时间。

你试试在maptest开头加一行await null会怎样

用户头像 回复 5月22日 @ Leo 中士 (1,325 威望)
选中 5月12日 @Twitch
提一个问题:

相关问题

0 投票
1 回复 229 阅读
用户头像 提问 2017年 4月25日 @ Rammus 上士 (1,530 威望)
0 投票
1 回复 148 阅读
用户头像 提问 2016年 7月24日 @ Caitlyn 上士 (1,887 威望)
0 投票
1 回复 14 阅读
用户头像 提问 5月17日 @ Hades 下士 (642 威望)
0 投票
1 回复 146 阅读

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

IT技术交流群 - 随意问
欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...