美文网首页
任务队列

任务队列

作者: 做个有趣的孩纸 | 来源:发表于2020-06-28 15:04 被阅读0次

1.案例

const useTime = t => {
let start = Date.now()
while(Date.now() - start < t) {}
}
let timer1 = setTimeout(() => {
console.log(3)
}, 500)
let timer2 = setTimeout(() => {
console.log(4)
}, 1000)
console.log(1)
useTime(2000)
console.log(2)

2.初步猜测结果

  • 打印猜测1,3,4,2 从上到下代码输出

3.测试验证,发现和预想不一致,为什么?

测试结果
1
2
<·underfined
3
4

4.原理讲解

  • 进入全局执行上下文
    <创建由第三方计时模块管理的timer1,timer1会在500ms后把任务fn1放入任务队列>
    <创建由第三方计时模块管理的timer2,time2会在1000ms后把任务fn2放入任务队列>
    <输出1>
  • 进入useTime执行上下文
    < 执行代码耗时2000ms,退出useTime执行上下文>
    在500ms和1000ms时timer1和timer2各自完成投放,此操作不属于JS主线
  • 返回全局执行上下文
    <输出2>
    同步任务执行完毕
    开始扫描任务队列
    取出队列的fn1
  • 进入fn1执行上下文
    <输出3,退出fn1执行上下文>
    取出队列的fn2
  • 进入fn2执行上下文
    <输出4,退出fn2执行上下文>
    循环扫描任务队列

5.范例

setTimeout(()=>{
console.log(1)
}, 0)
console.log(2)
let t = true
setTimeout(() => {
t = false
}, 1000)
while(t){ }
console.log('end')

相关文章

  • 同步任务队列、宏观任务队列、微观任务队列

    1、JS是单线程语言,包括同步任务、异步任务,异步任务又包括宏观任务和微观任务 2、执行顺序:同步任务——>微观任...

  • 同步任务队列、宏观任务队列、微观任务队列

    1、JS是单线程语言,包括同步任务、异步任务,异步任务又包括宏观任务和微观任务 2、执行顺序:同步任务——>微观任...

  • 关于GCD中的队列、线程、任务之间的关系及死锁的理解

    1. 任务与队列之间的关系 任务产生后被加入到某个队列中,队列仅保管任务,不执行任务; 队列分为串行队列和并行队列...

  • js运行机制

    在运行时会形成任务队列,分为同步任务队列和异步任务对列,同步队列优先加载异步任务队列会形成队列任务池,定时器不会一...

  • 2018-06-08 宏任务和微任务

    js先把宏任务放进宏任务队列里,再把微任务放进微任务队列里,执行的时候先执行宏任务队列里的一个任务,再把微任务队列...

  • GCD总结

    一.队列:这里的队列指执行任务的等待队列,即用来存放任务的队列。 二.在队列中加入任务1.队列中 添加 异步调用的...

  • nextTick、setImmediate、promise.re

    执行队列(同步) 任务队列(异步事件) 每当异步任务完成后会在任务队列中添加一个关联事件,待执行队列任务执行完成...

  • Redis入门(5) - 消息通知

    使用列表实现任务队列 优先级队列 按照规则订阅 Redis也可以作为任务队列。任务队列顾名思义,就是“传递任务的队...

  • 多线程02

    多线程2 GCD队列组: 基本使用: 常用函数 队列和组队列的区别 队列:封装任务,添加任务到队列 组队列:封装任...

  • 主队列和主线程

    队列的概念和作用: 队列不是线程,队列是用来组织任务的,将任务加到队列中,任务会按照加入到队列中先后顺序依次执行,...

网友评论

      本文标题:任务队列

      本文链接:https://www.haomeiwen.com/subject/itcwfktx.html