微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

【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()
}

原文地址:https://www.jb51.cc/wenti/3283224.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐