温故知新(九五)promise 并发 和 按顺序执行

并发可以直接使用 Promise.all 进行多个 Promise 并发执行

按顺序执行:

        1.可以使用 async 函数里面的 for of 进行迭代

        2.可以使用 reduce 函数进行迭代调用

调用的promise

const sleep = () => {
  return new Promise((resolve, reject) => {
    setTimeout(function(){
      console.log('sleep')
      resolve()
    }, 1000)
  })
}


const promiseList = [
  sleep,
  sleep,
  sleep
]

并发执行:

console.log('Promise.all start', new Date().getTime())
Promise.all(
  promiseList.map(item => item())
).then(() => {
  console.log('Promise.all end', new Date().getTime())
})

并发执行还可以使用 async await 函数,更加简洁明了

async function fn() {
  const sleep1 = sleep1()
  const sleep2 = sleep2()
  const sleep3 = sleep3()
  // 下面三个写的顺序跟总共所花的时间无关,无论谁先谁后,总共时长一样
  const res1 = await sleep1
  const res2 = await sleep2
  const res3 = await sleep3
  console.log(res1, res2, res3)
  // 上面总体等同于:
  /**
  const sleep1 = new Promise((resolve) => {
    sleep1().then(resolve)
  })
  const sleep2 = new Promise((resolve) => {
    sleep2().then(resolve)
  })
  
  sleep1.then(()=>{
    sleep2.then(()=>{
      
    })
  })
  
  **/
}

 

按顺序迭代:

1、async  for of

async function forOfPromise() {
  console.log('for of start', new Date().getTime())
  async function forOfLoop() {
    for (const promiseInstance of promiseList) {
      await promiseInstance()
    }
  }
  await forOfLoop()
  console.log('for of end',  Date.now())
}
forOfPromise()

 2、reduce

const promiseChain = promiseList.reduce((prev, current) => {
  // 如果是实例
  if (prev.then) {
    return prev.then(current)
  }
  // 如果是构造函数
  return prev().then(current)
})
promiseChain.then(_=>console.log('promisechain completed'))

上面的 reduce 可以给一个初始值

const promiseChain2 = promiseList.reduce((prev, cur) => {
  return prev.then(cur)
}, Promise.resolve())

你可能感兴趣的:(温故知新,javascript)