博客
关于我
Event Loop详解
阅读量:257 次
发布时间:2019-03-01

本文共 927 字,大约阅读时间需要 3 分钟。

Event Loop

先举一个列子

console.log('start');setTimeout(() => {  console.log('timeout');});Promise.resolve().then(() => {  console.log('resolve');});console.log('end');
  • 刚开始整个脚本作为一个宏任务来执行,对于同步代码直接压入执行栈(关于执行栈,因此先打印start和end
  • setTimeout 作为一个宏任务放入宏任务队列
  • Promise.then作为一个为微任务放入到微任务队列
  • 当本次宏任务执行完,检查微任务队列,发现一个Promise.then执行
  • 接下来进入到下一个宏任务——setTimeout执行
  • 因此依次输出start end resolve timeout

什么是Event Loop

主线程从任务队列中读取事件,这个过程是循环不断的,所以整个的这种运行机制又称为Event Loop(事件循环)。

上图中,主线程运行的时候,产生堆(heap)和栈(stack),栈中的代码调用各种外部API,它们在任务队列中加入各种事件(click,load,done)。只要栈中的代码执行完毕,主线程就会去读取任务队列,依次执行那些事件所对应的回调函数。

在Javascript的Event Loop机制中,存在两个任务队列:Macrotask queue(宏队列)和Microtask queue(微队列)。

如果你想让一个异步任务尽快执行,那么就把它设置为Microtask,除此之外都用Macrotask。因为,虽然Javascript是异步非阻塞的,但在一个事件循环中,Microtask的执行方式基本上就是用同步的。

Event Loop的循环机制

 

  1. 一开始整段脚本作为第一个宏任务执行
  2. 执行过程中同步代码直接执行,宏任务进入宏任务队列,微任务进入微任务队列
  3. 当前宏任务执行完出队,检查微任务队列,如果有则依次执行,直到微任务队列为空
  4. 执行浏览器 UI 线程的渲染工作
  5. 检查是否有Web worker任务,有则执行
  6. 执行队首新的宏任务,回到2,依此循环,直到宏任务和微任务队列都为空
你可能感兴趣的文章
RTSP/RTP协议直播推送库EasyPusher推RTSP流至EasyDarwin开源平台实现自定义Stream
查看>>
ESP32 基础篇:ESP-IDF 编程指南
查看>>
andriod错误收集及解决不断更新
查看>>
VUE使用 wx-open-launch-app 组件开发微信打开APP功能
查看>>
intellij 提示 java-numbers.iml does not exist 不存在
查看>>
Confluence 6 让 Jira 应用停止发送通知到 Confluence
查看>>
【OpenCV】 2.4.13-编程过程遇到问题记录
查看>>
Wireshark抓包实验
查看>>
maven仓库设置,windows和mac
查看>>
Android错误收集
查看>>
浙大机器学习课程-8-支持向量机(原问题转化为对偶问题)
查看>>
css3之路- 结构性伪类
查看>>
239_自定义View画圆环环形
查看>>
流媒体音视频服务云管理平台EasyNVS平台中视频播放页面出现错误码的问题解决
查看>>
渗透测试学习笔记之案例五
查看>>
Pentest Wiki Part4 后渗透(二)
查看>>
tomcat配置虚拟目录后出现404的解决方法
查看>>
/usr/bin/ld: cannot find -ltcmalloc 错误的解决方法
查看>>
【python】protobuf 使用学习记录
查看>>
php许愿墙
查看>>