勾勾-MIAN
创始人
2024-02-27 21:00:52
0
  1. 谈谈你是如何理解JS异步编程的、EvenLoop、消息队列、宏任务 和 微任务的?

JS异步编程
JS的执行环境是单线程的,一次只能执行一个任务,多任务需要排队等候,这种模式可能会阻塞代码,导致代码执行效率降低。为避免这种问题,出现了异步编程。一般通过callback 函数,事件发布/订阅、Promise 等来组织代码。本质上都是通过回调函数来实现异步代码的存放和执行。

EvenLoop 事件环 和 消息队列
EventLoop 是一种循环机制,不断轮训消息队列,从中找到需要执行的任务并按顺序执行的一个执行模型。
消息队列 用来存放宏任务的队列,比如定时器到了,定时器内的方法引用会存到改队列,ajax 的回调方法。

一开始整个脚本作为一个宏任务执行,执行过程中同步代码直接执行,宏任务等事件到达或者成功后,将方法的回调放入宏任务队列中,微任务进入微任务队列中。
当前主线程的宏任务执行完出队,检查并清空微任务队列,接着执行浏览器的UI线程的渲染工作。检查Web worker 任务,有则执行。
然后再取出一个宏任务执行。以此循环…

宏任务 和 微任务
宏任务 每次执行栈执行的代码就是宏任务(包括每次从事件队列中获取一个事件回调并放到执行栈中执行)。浏览器为了让JS 内部宏任务 与DOM 操作有序的执行,会在一个宏任务执行结束后,在下一个宏任务执行之前,对页面进行重新渲染。
宏任务包括:script(整体代码)、setTimeout、setInterval、I/O、UI交互事件、MessageChannel 等

微任务 当前任务执行结束后需要立即执行的任务。也就是说,在当前任务后,渲染之前,执行清空微任务。
所以它的响应速度相比宏任务会更快,因为无需等待UI渲染。
微任务包括:Promise.then、MutaionObserver、process.nextTick(Node.js 环境)等

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【Ctfer训练计划】——(三... 作者名:Demo不是emo  主页面链接:主页传送门 创作初心ÿ...