EventLoop(回顾)

JavaScript是一种单线程语言,采用EventLoop事件循环机制来处理同步和异步任务。同步任务按顺序执行,而异步任务分为宏任务和微任务,宏任务包括script、setTimeout等,微任务如Promise。执行过程是先执行宏任务,完成后处理微任务队列,然后更新UI,如此循环。这种机制可能导致setTimeout等的执行时间不精确。

基本概念

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 渲染操作、更新界面。

参考

链接

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

柳晓黑胡椒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值