关于EventLoop的简单理解

本文探讨了JavaScript单线程的原因及其带来的同步问题,介绍了宏任务与微任务的来源,并通过执行顺序图解解释了EventLoop的工作原理。重点讲解了如何通过EventLoop处理IO阻塞,提升Web应用性能。
摘要由CSDN通过智能技术生成

个人博客网站欢迎交流:萤火之森:https://blog.xkongkeji.com

EventLoop出现的目的

js单线程

众所周知js是单线程的,那为什么是单线程嘞,作为浏览器脚本语言,JavaScript的主要用途是与用户互动,以及操作DOM。这决定了它只能是单线程,否则会带来很复杂的同步问题。比如,假定JavaScript同时有两个线程,一个线程在某个DOM节点上添加内容,另一个线程删除了这个节点,这时浏览器应该以哪个线程为准?

单线程解决方案

单线程就意味着,所有任务需要排队,前一个任务结束,才会执行后一个任务。如果前一个任务耗时很长,后一个任务就不得不一直等着。如果排队是因为计算量大,CPU忙不过来,倒也算了,但是很多时候CPU是闲着的,因为IO设备(输入输出设备)很慢(比如Ajax操作从网络读取数据),不得不等着结果出来,再往下执行。于是就有了EventLoop的出现。

宏任务与微任务从哪里来

微任务

  • Promise ,当调用 Promise.resolve() 或者 Promise.reject() 的时候,会产生微任务。
  • MutationObserver 接口,监听DOM节点发生改变的时候,就会产生 DOM 变化记录的微任务。
  • Process.nextTick(Node独有)

宏任务

  • 渲染事件(如解析 DOM、计算布局、绘制)
  • 用户交互事件(如鼠标点击、滚动页面、放大缩小等)
  • JavaScript 脚本执行事件
  • 网络请求完成、文件读写完成事件

执行顺序图解(图片来自网络)

个人理解

  • js会先执行主线程任务,遇到微任务就放进微任务队列,遇到宏任务就放入宏任务队列。
  • 主线程代码执行完成后就会从微任务队列中去取微任务执行直到微任务队列清空,
  • 微任务队列完成后就会从宏任务队列中取出宏任务执行,(个人理解:主线程代码就是第一个宏任务) 如主线程任务一般,遇到微任务放入微任务队列,遇到宏任务放入宏任务队列。
  • 重复此过程,这就是事件循环机制。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值