【JS】实现一个队列处理程序,当传入任务队列时,能够串行地处理完任务

题目说明

  • 请实现一个队列处理程序,当传入任务队列时,能够串行地处理完任务,
  • 如果传入的任务包含异步执行,那么必须确保异步执行完毕之后才会执行后面的任务。
function queue(list){
}

function task1(next){
  setTimeout(function(){
    console.log(1);
    next();
  }, 1000)
}
function task2(next){

  console.log(2)
  next();
}
function task3(next){

  setTimeout(function(){
    console.log(3);
    next();
  }, 200)
}
queue([task1, task2, task3])
// 按顺序输出 1, 2, 3

解法一:Promise

    function queue(list) {
      list.reduce(
        (p, cur) => p.then(() => new Promise((resolve) => cur(resolve))),
        Promise.resolve()
      )
    }
  • 利用reduce迭代队列,初始化一个成功的Promise对象,将resolve函数作为参数传入队列函数中,因此,当输出1后,执行resolve()时 ,Promise状态才改变,此时p替代。

解法二:async

  • 将每一个队列参数包装成Promise
	async function queue(list) {
      for (let index = 0; index < list.length; index++) {
        const element = list[index]
        await makePromise(element)
      }
    }

    function makePromise(fn) {
      return new Promise((resolve) => {
        fn(resolve)
      })
    }

解法三:递归

function queue(list) {
  list= [...list]
  const step = () => {
    const run = list.shift()
    if (run) {
      run(step)
    }
  }
  step()
}

相关文章

显卡天梯图2024最新版,显卡是电脑进行图形处理的重要设备,...
初始化电脑时出现问题怎么办,可以使用win系统的安装介质,连...
todesk远程开机怎么设置,两台电脑要在同一局域网内,然后需...
油猴谷歌插件怎么安装,可以通过谷歌应用商店进行安装,需要...
虚拟内存这个名词想必很多人都听说过,我们在使用电脑的时候...
win11本地账户怎么改名?win11很多操作都变了样,用户如果想要...