浏览器中的Event loop

浏览器中的Event Loop(事件循环)
1、JS的特点
Javascript是一种单线程非阻塞的脚本语言,单线程的解释是:在任何时候,只有一个主线程执行任务;非阻塞的解释为:主线程不会直接处理异步任务,而是异步操作返回结果后才去处理异步任务,由于异步操作的存在会阻塞浏览器的渲染
2、宏任务与微任务
宏任务:严格按照时间顺序压栈和执行的任务,比如:setTimeout,setInterval
微任务:需要在当前主线程执行结束后立即执行的任务,比如:Promise
3、event loop的执行步骤
(1)执行宏任务,一次循环只执行一个宏任务
(2)主线程为空时取出微任务执行(先进先出),直到微任务队列为空
(3)完成一轮循环,反复执行上述步骤
4、示例

console.log("script1")
Promise.resolve().then(()=>{
  console.log("Promise1")
});
setTimeout(()=>{
  console.log("setTimeout")
},0);
Promise.resolve().then(()=>{
  console.log("Promise2")
});
console.log("script12");

输出结果:
在这里插入图片描述

执行过程:
在这里插入图片描述
(1)主线程被JS引擎执行,当前是一个宏任务,输出script1
(2)Promise.resolve()回调进入微任务1
(3)执行setTimeout,回调进入下一个应该被执行的宏任务
(4)Promise.resolve()回调进入微任务2
(5)输出script12,当前宏任务执行完毕
(6)检测到存在微任务列表,执行微任务列表,按顺序执行微任务1,微任务2,此时微任务列表为空
(7)执行下一个宏任务setTimeout,并且不存在微任务列表,执行结束

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值