同步任务、异步任务、宏任务、微任务基本概念

阅读: 评论:0

同步任务、异步任务、宏任务、微任务基本概念

同步任务、异步任务、宏任务、微任务基本概念

同步任务: 指的是在主线程上排队执行的任务,只有前一个任务执行完毕,才能执行后一个任务。
异步任务: 指的是不进入主线程,某个异步任务可以执行了,该任务才会进入主线程执行。

异步执行的运行机制如下(同步任务也如此,因为它可以被视为没有异步任务的异步执行):
  1. 所有同步任务都在主线程上执行,形成一个执行栈(execution context stack)
  2. 主线程之外,还存在一个“任务队列”,只要异步任务有了运行结果,就在“任务队列”之中放置一个事件
  3. 一旦“执行栈”中的所有同步任务执行完毕,系统就会读取“任务队列”,看看里面有哪些事件。那些对应的异步任务,于是结束等待,进入执行栈,开始执行
  4. 主线程不断重复第3步

javascript提供的与“任务队列”有关的方法有:setTimeout、setInterval、Tick和setImmediate。

setImmediate方法则是在当前“任务队列”的尾部添加事件,也即是说,它指定的任务总是在下一次Event Loop时执行。

内容来自阮一峰博客。

宏任务macrotask: 可以理解是每次执行栈执行的代码就是一个宏任务(包括每次从事件队列中获取一个事件回调并放到执行栈中执行)。主要场景有:主代码块、setTimeout、setInterval等
微任务microtask: 可以理解是在当前task执行结束后立即执行的任务。主要场景有:Promise、Tick等。

本文发布于:2024-01-31 14:10:23,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170668142629086.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:基本概念
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23