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

前端面试高频考点—事件循环Event loop

目录

事件循环

执行步骤

概念讲解

主线程

微任务(micro task)

宏任务(macro task)

Event Loop经典例题

这段代码的执行结果是什么?

正确答案:

具体流程:


事件循环

主线程从"任务队列"中读取执行事件,这个过程是循环不断的,这个机制被称为事件循环。

(JS的运行机制就是事件循环!)

执行步骤

主线程任务——>微任务——>宏任务 如果宏任务里还有微任就继续执行宏任务里的微任务,如果宏任务中的微任务中还有宏任务就在依次进行

同步的任务没有优先级之分,异步执行有优先级,先执行微任务(microtask队列),再执行宏任务(macro task队列),同级别按顺序(先微任务后宏任务)

概念讲解

主线程

所有的同步任务都是在主线程里执行的,异步任务可能会在macrotask或者microtask里面

微任务(micro task)

  • promise
  • async
  • await
  • process.nextTick(node)
  • mutationObserver(html5新特性)

宏任务(macro task)

  • script(整体代码)
  • setTimeout
  • setInterval
  • setImmediate
  • I/O
  • UI render

Event Loop经典例题

这段代码的执行结果是什么?

console.log('1')

setTimeout(function callback(){
	console.log('2')
}, 1000)

new Promise((resolve, reject) => {
    console.log('3')
    resolve()
})
.then(res => {
    console.log('4');
})

console.log('5')

正确答案:

        1,3,5,2,4

具体流程:

参考文章:

 一看就懂的事件循环机制(event loop) - 掘金 (juejin.cn)


到底什么是Event Loop?那就来了解一下JavaScript分别在浏览器和Node环境下的运行机制吧-CSDN博客


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

相关文章:

  • 『heqingchun-Ubuntu系统+x86架构+配置编译安装使用yolov5-6.0+带有TensorRT硬件加速+封装动态库+C++部署+Qt』
  • 登录/注册波形库账号(英国Pico汽车论坛账号)
  • 2023-12-01 AIGC-自动生成ppt的AI工具
  • C#多线程开发之----List Task有返回值
  • RPG项目01_场景及人物动画管理器
  • 【零基础入门Docker】Dockerfile中的USER指令以及dockerfile命令详解
  • C++ 传递指针给函数
  • 从PDF和图像中提取文本,以供大型语言模型使用
  • java开发之个微群聊自动添加好友
  • scrapy爬虫中间件和下载中间件的使用
  • git基本概念
  • 【概率统计】如何理解概率密度函数及核密度估计
  • Doris 数据导入一:Broker Load 方式
  • 树莓派3B+ PCB叠层设计
  • 连锁零售企业如何提高异地组网的稳定性?
  • PVE系列-LVM安装MacOS的各个版本
  • github / gitlab s申城 配置密钥 ssh key
  • 【SparkSQL】SparkSQL函数定义(重点:定义UDF函数、使用窗口函数)
  • 【Linux--进程控制】
  • 简单小结类与对象