当前位置: 首页 > article >正文

EventLoop(回顾)

  • 基本概念
    • 影响
  • JavaScript是单线程的语言
  • 同步任务和异步任务
  • 同步任务和异步任务的执行过程
  • 宏任务和微任务
  • 宏任务和微任务的执行过程

基本概念

JavaScript主线程从"任务队列"中读取异步任务的回调函数,放到执行栈中依次执行,这个过程是循环不断的,所以整个的这种运行机制又称为EventLoop(事件循环机制),负责执行代码、收集处理事件以及执行队列中的子任务

影响

Event Loop 的设计会带来一些问题,比如setTimeout、setInterval的时间精确性

// 启动计时器
console.time('testForEach');
setTimeout(()=>{
    // 停止计时,输出时间
    console.timeEnd('testForEach');
},2000)

JavaScript是单线程的语言

JavaScript是一门单线程执行的编程语言,也就是说同一时间只能做一件事
在这里插入图片描述

单线程执行任务队列的问题:
如果前一个任务非常耗时,则后续的任务就不得不一直等待,从而导致程序假死现象

同步任务和异步任务

同步任务(synchronous)

指的是在主线程上排队执行的任务
只有前一个任务执行完毕,才能执行后一个任务

异步任务(asynchronous)

异步任务由JavaScript委托给宿主环境进行执行
当异步任务执行完,会通知JavaScript主线程执行异步任务的回调函数

同步任务和异步任务的执行过程

经典题目

例题

例题2
同步任务和异步任务的执行过程

宏任务和微任务

宏任务

包括 script 全部代码setTimeoutsetInterval、setImmediate(Node.js)、requestAnimationFrame(浏览器)、I/O 操作、UI 渲染(浏览器),这些代码执行便是宏任务。

微任务

包括process.nextTick(Node.js)PromiseMutationObserver(监听DOM),这些代码执行便是微任务

宏任务和微任务的执行过程

先微后宏

  • 宏任务队列一次只从队列中取一个任务执行,执行完后就去执行微任务队列中的任务。
  • 微任务队列中所有的任务都会被依次取出来执行,直到微任务队列为空。
  • 执行完所有的微任务之后,执行下一个宏任务之前,浏览器会执行 UI 渲染操作、更新界面。

参考

链接


http://www.kler.cn/a/2592.html

相关文章:

  • 记录一次面试中被问到的问题 (HR面)
  • [离线数仓] 总结二、Hive数仓分层开发
  • 计算机网络基础——网络协议
  • Unity Burst详解
  • unity学习14:unity里的C#脚本的几个基本生命周期方法, 脚本次序order等
  • 快速上手:采用Let‘sEncrypt免费SSL证书配置网站Https (示例环境:Centos7.9+Nginx+Let‘sEncrypt)
  • JVM系统优化实践(11):GC如何搞垮线上系统
  • Unity脚本类 ---- Input类,虚拟轴与插值方法
  • 第四季新星计划即将开启,博客之星取消拉票你怎么看?
  • 音乐制作:Ableton Live 11 Suite Mac
  • 全面比较Aptos和Sui:Aptos已上线 来看看Sui
  • 56 | fstab开机挂载
  • 【刷题之路Ⅱ】牛客 NC107 寻找峰值
  • 01. Vue核心 Vue简介 初识
  • 智能灯泡一Homekit智能家居系列
  • 【算法题】2191. 将杂乱无章的数字排序
  • Spring教程——Spring IoC(控制反转)
  • Docker—苹果Mac安装Docker的两种方式
  • 真要被00后职场整顿了?老员工纷纷表示真的干不过.......
  • Java - 配置中心初体验
  • Nginx可视化管理工具 - Nginx Proxy Manager
  • three.js中创建文字(Creating text)
  • 难以置信,已经有人用 ChatGPT 做 Excel 报表了?
  • Spring Boot 3.0系列【22】应用篇之嵌入式 Servlet 容器
  • 离线安装ffmpeg
  • Centos7 XFS(dm-0):Internal error XFS_WANT_CORRUPTED_GOTO