Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

设计一个简单的任务队列, 要求分别在 1,3,4 秒后打印出 "1", "2", "3"; #150

Open
Sunny-117 opened this issue Nov 3, 2022 · 8 comments

Comments

@Sunny-117
Copy link
Owner

No description provided.

@mengqiuleo
Copy link

题目:

 new Quene()
        .task(1000, () => {
            console.log(1)
        })
        .task(2000, () => {
            console.log(2)
        })
        .task(1000, () => {
            console.log(3)
        })
        .start()

function Quene() { ... } //补全代码

实现:

function Queue() {
  this.quene = [];
}


Queue.prototype.task = function (time, callback) {
  this.quene.push({ time, callback });
  return this;
};

Queue.prototype.start = function () {
  const quene = this.quene;
  let result = Promise.resolve();

  quene.forEach((item) => {
    result = result.then(() => {
      return new Promise((resolve, reject) => {
        setTimeout(() => {
          resolve(item.callback());
        }, item.time);
      });
    });
  });

  return result;
};

//test
new Queue()
  .task(1000, () => {
    console.log(1)
  })
  .task(2000, () => {
    console.log(2)
  })
  .task(1000, () => {
    console.log(3)
  })
  .start()

@QdabuliuQ
Copy link

   class TaskQueue {
      constructor() {
        this.queue = []
      }
      add(time, fn, ...args) {
        let p = () => {
          return new Promise((resolve) => {
            setTimeout(() => {
              resolve(fn(...args))
            }, time);
          })
        }
        this.queue.push(p)
        return this
      }
      async execute() {
        let results = []
        while(this.queue.length) {
          await this.queue.shift()().then(res => results.push(res))
        }
        return results
      }
    }

    let q =new TaskQueue()
    console.log(q.add(1000, () => {
      console.log(1)
      return '1'
    }).add(2000, () => {
      console.log(2)
      return '2'
    }).add(1000, () => {
      console.log(3)
      return '3'
    }).execute().then(res => console.log(res)));

@l1ax
Copy link

l1ax commented Jun 27, 2023

class Quene {
  constructor() {
    this.queue = [];
  }

  task(time, cb) {
    this.queue.push(() => this.timeWait(time));
    this.queue.push(() => cb());
    return this;
  }
  timeWait(time) {
    return new Promise((resolve) => setTimeout(resolve, time));
  }
  start() {
    setTimeout(async () => {
      for (const task of this.queue) {
        await task();
      }
    }, 0);
  }
}

@SiriusZHT
Copy link

// 设计一个简单的任务队列, 要求分别在 1,3,4 秒后打印出 "1", "2", "3";
function Quene() { 
    const queue = []
    function task(delay, fn) {
        const promise = () => Promise.resolve().then(() => 
            new Promise((res) => 
                setTimeout(() => {
                    fn()
                    res()
                }, delay)
            )
        )
        queue.push(promise)
        return this
    }
    async function start() {
        for(let task of queue) {
            await task()
        }
    }
    return {
        task: task,
        start: start
    }
}

new Quene()
.task(1000, () => {
    console.log(1)
})
.task(2000, () => {
    console.log(2)
})
.task(1000, () => {
    console.log(3)
})
.start()

@tyust512
Copy link

new Quene()
  .task(1000, () => {
    console.log(1);
  })
  .task(2000, () => {
    console.log(2);
  })
  .task(1000, () => {
    console.log(3);
  })
  .start();

function Quene() {
  const queue = []
  this.task = function(timeout, callback) {
    function callbackWrapper() {
      return new Promise((resolve) => {
        setTimeout(() => {
          callback()
          resolve()
        }, timeout)
      })
    }
    queue.push(callbackWrapper)
    return this
  }

  this.start = async function() {
    while(queue.length) {
      const task = queue.shift()
      await task()
    }
    
  }
}

@coderTopu
Copy link

/**
 *  new Quene()
 *         .task(1000, () => {
 *             console.log(1)
 *         })
 *         .task(2000, () => {
 *             console.log(2)
 *         })
 *         .task(1000, () => {
 *             console.log(3)
 *         })
 *         .start()
 *
 * function Quene() { ... } //补全代码
 */

// 定义task代码,task将调用的信息push到quene中
Quene.prototype.task = function (time, callback) {
  this.quene.push({ time, callback })
  // 将Quene的实例返回出来,后面的task才可以调用
  return this
}

// 定义start代码
Quene.prototype.start = async function () {
  for (let i = 0; i < this.quene.length; i++) {
    await new Promise((resolve, reject) => {
      setTimeout(() => {
        resolve()
      }, this.quene[i].time)
    }).then(() => {
      this.quene[i].callback()
    })
  }
}


new Quene()
.task(1000, () => {
  console.log(1)
})
.task(2000, () => {
  console.log(2)
})
.task(1000, () => {
  console.log(3)
})
.start()

function Quene () {
  this.quene = []
}

@keyuxu01
Copy link

keyuxu01 commented Nov 3, 2024

Quene.prototype.task = function(timer, callback) {
    this.queue.push({timer, callback})
    return this;
}

Quene.prototype.start = function() {
    const promiseArray = this.queue.map(item => new Promise<void>(
        (resolve, reject) => {
            setTimeout(() => {
                item.callback(); // 执行任务的回调
                resolve(); // 任务完成,resolve
            }, item.timer);
        }
    ))

    Promise.all(promiseArray)
}

new Quene()
    .task(1000, () => {
        console.log(1)
    })
    .task(2000, () => {
        console.log(2)
    })
    .task(1000, () => {
        console.log(3)
    })
    .start()

@zjuxiaowu
Copy link

// 发一下我写的嘿嘿
function Queue(){
this.queue = [];
this.isWorking = false;

}

Queue.prototype.task = function(time, fn){
this.queue.push({
time,
fn
})

return this
}

Queue.prototype.start = function(){
if(!this.queue.length) return;
const obj = this.queue.shift()
new Promise(resolve=>{
setTimeout(()=>{
obj.fn()
resolve()
}, obj.time)
}).then(this.start.bind(this))
}

new Queue()
.task(1000, () => {
console.log(1)
})
.task(2000, () => {
console.log(2)
})
.task(1000, () => {
console.log(3)
})
.start()

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

9 participants