EventLoop事件循环 、微任务队列和宏任务队列

javaScript 是一门单线程执行的脚本语言。也就是说,同一时间只能做一件事情。

javaScript要运行在宿主环境中(浏览器,nodejs)下。浏览器内部有执行js代码的引擎(V8引擎)

浏览器的事件循环

排队是任务是以事件及其回调的方式存在的。

当事件(用户的点击,图片的成功加载)发生时,将其回调添加到任务队列;主线程上的任务完成之后,就会从任务队列中取出任务来执行。

js是单线程的,一次只能做一件事。js在浏览器这个宿主环境中运行。浏览器是多线程的,用户交互,定时器,网络请求等等浏览器中的事件会产生对应的任务,任务多了要在任务队列中排队,浏览器的主线程依次取出任务来执行,此过程不断重复从而形成一个循环,称为eventLoop。

微任务队列和宏任务队列

微任务代码(js语法)

  • Promise对象.then()

宏任务代码(宿主环境)

  • script
  • dom事件
  • ajax
  • setTimout
  • 画图

微任务在进程的执行过程中相对于同级别的宏任务可以优先执行

 

JavaScript事件循环(Event Loop)是 JavaScript 运行机制中的核心部分,负责处理异步操作线程调度。它是 JavaScript 中实现非阻塞I/O响应用户交互的关键。 **异步/同步:** - **同步**(Synchronous):代码按照顺序执行,每个任务完成后才会执行下一个任务。如果某个任务耗时较长,将导致整个程序暂停直到该任务完成。 - **异步**(Asynchronous):代码执行不会被阻塞,当遇到异步任务(如定时器、网络请求或读取文件)时,JavaScript会继续执行后续的同步代码,而把异步任务放到后台等待处理,完成后通过回调、Promise 或 async/await 结合事件循环来通知主线程。 **宏任务/微任务:** - **宏任务(Macrotask)**:指的是那些浏览器可以感知到的任务,比如脚本执行、UI渲染、DOM操作、setTimeout setInterval 回调等。每次事件循环开始,都会先执行所有已排队的宏任务。 - **微任务(Microtask)**:微任务比宏任务优先级高,它们通常是在某些特定情况下生成的,例如 Promise 的 resolve 或 reject 时、MutationObserver 观察到 DOM 变化时、process.nextTick() 执行的内容。每当宏任务执行完毕,立即执行所有的微任务。 简而言之,事件循环的工作流程大致如下: 1. 执行当前同步代码块。 2. 如果有微任务,立即执行微任务。 3. 宏任务队列中如果有任务,执行宏任务。 4. 完成当前宏任务后,再次检查是否有微任务并执行。 5. 重复步骤34,直到没有更多任务。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值