async/await并行编程总结

日常使用async/await这对好基友的时候,多数是用一函数把它们包起来或者直接使用,如以下写法

function getName () {
    return new Promise((resolve, reject)=>{
        setTimeout(()=>{
            resolve('lcwai')
        }, 2000)
    })
}
function getId () {
    return new Promise((resolve, reject)=>{
        setTimeout(()=>{
            resolve('456')
        }, 3000)
    })
}
console.log(new Date().getTime())

async function show() {
    let name = await getName()
    let id = await getId()
    console.log(`name:${name}, id:${id}`)
    console.log(new Date().getTime())
}

show()

结果:5s

1602553423357
name:lcwai, id:456
1602553428370

好明显看到是串行,但是遇到一些并行处理的场景,这样会很悲催。

下面总结一下自己所用到一些串行写法。
1、先生成所有 promise 实例,再调用

;(async ()=>{
    let namePromise = getName()
    let idPromise = getId()              
    let name1 = await namePromise
    let name = await namePromise
    let id = await idPromise
    console.log(`name:${name}, id:${id}, name1: ${name1}`)
    console.log(new Date().getTime())
})()

结果:3s

1602554099501
name:lcwai, id:456, name1: lcwai
1602554102512

2、使用Promise.all

;(async ()=>{
    var result = await Promise.all([getName(), getId()])
    console.log(`name:${result[0]}, id:${result[1]}`)
    console.log(new Date().getTime())
})()

结果:3s

1602554183102
name:lcwai, id:456
1602554186112

3、使用Q.allSettled

const Q = require('q');
Q.allSettled([
    getName(), 
    getId()
]).spread(async function (gnRet, giRet) {
    console.log(gnRet, giRet)
    console.log(new Date().getTime())
}).done();

结果:3s

1602554375226
{ state: ‘fulfilled’, value: ‘lcwai’ } { state: ‘fulfilled’, value: ‘456’ }
1602554378248

4、使用Q.all

const Q = require('q');
Q.all([
    getName(), 
    getId()
]).done(v => {
    console.log(v)
    console.log(new Date().getTime())
});

结果:3s

1602554466047
{ state: ‘fulfilled’, value: ‘lcwai’ } { state: ‘fulfilled’, value: ‘456’ }
1602554469067

这4种方法有什么好坏处呢?
方法1、2无需引入新的包,而3、4则需要引入q包;
如果链式调用没有resolve返回,只有reject的话,方法1,2,4都会有报错而无法接收到需要的值,方法3则能接收到需要的状态返回。

因此:在确保全部异常都能捕捉并很好地处理的情况下,4种方法随便用。如果是不太熟练,建议优先使用方法3。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lcwai

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值