返回顶部
首页 > 资讯 > 精选 >Javascript的Event Loop怎么实现
  • 490
分享到

Javascript的Event Loop怎么实现

2023-06-22 06:06:23 490人浏览 薄情痞子
摘要

本篇内容主要讲解“javascript的Event Loop怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Javascript的Event Loop怎么实现”吧!一、

本篇内容主要讲解“javascript的Event Loop怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Javascript的Event Loop怎么实现”吧!

一、四个概念

1、Javascript是单线程

单线程意味着我们的js代码只能从上往下同步执行,同一时间只能执行一个任务,这会导致某些执行时间较长或者执行时间不确定的任务会卡住其它任务的正常执行,Event Loop出现的原因正是为了解决此问题。

2、任务队列

为了解决上述的排队问题,有了任务队列,浏览器在异步任务有了结果后,将其添加到任务队列,以待将来执行,其他任务就在主线程上同步执行。

这里要注意的是,向任务队列中添加任务的时机是异步任务有结果后。其实任务队列中存在的就是异步任务的回调函数。

3、同步任务、异步任务

Js程序中的同步任务是指在主线程中执行的任务,异步任务是指进入任务队列中的任务

4、Javascript执行栈

所有的同步任务都在主线程上执行,行成一个执行栈。当主线程上任务执行完毕后,从任务队列中取出任务执行。

var name = "zhouwei";setTimeout(() => {    console.log(1);}, 1000);console.log(name);

上面代码在浏览器中执行如下,我们将程序全局执行环境的代码理解为包裹在一个main函数中的代码,这段代码的执行栈变化如下图:

Javascript的Event Loop怎么实现

  • 开始执行代码,将main任务(全局代码入栈执行),当遇到异步任务(setTimeout后)。

  • 浏览器接管异步任务,并在1s后将异步任务的结果(回调函数)添加到任务队列。

  • 执行栈中的同步任务执行完毕,此时任务队列为空(未到1s),执行栈也为空

  • 异步任务有结果后,首先进入任务队列排队(因为可能有很多异步任务)。

  • 执行栈从任务队列中取出任务开始同步执行。

  • 重复执行第5步。

二、Event Loop

Js执行栈不断的从任务队列中读取任务并执行的过程就是Event Loop

我们知道任务队列中存放的是异步任务的结果,那么异步任务都有哪些了?

  • 1、事件

Javascript中的事件有很多,都是属于异步任务。由浏览器接管,当事件触发时,将事件的回调加入的任务队列中,在Js执行栈中没有任务时执行。

  • 2、Http请求

  • 3、定时器

  • 4、requestAnimationFrame等

宏任务(Macrotask)和微任务(microtask)
在了解了任务队列和Event Loop后,我们知道了Js执行栈从任务队列中读取任务执行,但这个具体工程我们任务不清楚,这里引出了宏任务和微任务的的概念,帮助我们理解Event Loop。

进入任务队列中的异步任务回调分为了宏任务和微任务, Js执行栈执行宏任务和微任务的规则如下图所示。

Javascript的Event Loop怎么实现

Js执行栈首先执行一个宏任务(全局代码) -> 从任务队列中读取所有微任务执行 -> UI rendering(浏览器渲染界面) -> 从任务队列读取一个宏任务 -> 所有微任务 -> UI rendering -> …

在每一轮的Event Loop结束后(1个宏任务 + 所有微任务),浏览器开始渲染界面(如果有需要渲染的UI,否则不执行UI rendering),在UI rendering结束后,开始下一轮Event Loop。

哪些是宏任务?

  • setTimeout

  • setInterval

  • setImmediate (node)

  • requestAnimationFrame (浏览器)

  • I/O (事件回调)

  • UI rendering (浏览器渲染)

哪些是微任务?

  • Promise

  • process.nextTick (Node)

  • MutationObserver (现代浏览器提供的用来检测 DOM 变化的网页接口)

setTimeout延时问题

一般来说在代码中setTimeout中回调的执行时间都是大于设置的时间。 这是因为在setTimeout指定时间到达后,虽然回调函数被添加到了任务队列,但是此时Js执行栈中可能有正在执行的任务,此回调需要等待Js执行栈的任务执行完毕后才有机会执行,这就是setTimeout延时问题。

三、实战

练习下下方代码输出结果吧:

console.log(1);setTimeout(() => {    console.log(2);    Promise.resolve().then(() => {        console.log(3)    });});new Promise(resolve => {    console.log(4);    setTimeout(() => {        console.log(5);    });    resolve(6)}).then(data => {    console.log(data);})setTimeout(() => {    console.log(7);})console.log(8);

用上方的我们说过的js执行机制来分析这道题:

1: 执行全局任务中的同步代码输出:

1
4
8

这里需要注意的是Promise接受的handle函数是同步任务,而then方法是异步任务,所以会直接输出4。

2: 这时的任务队列中有三个setTimeout的宏任务,和一个Promise的微任务

// 此时的宏任务是setTimeout(() => {    console.log(2);    Promise.resolve().then(() => {        console.log(3)    });});setTimeout(() => {    console.log(5);});setTimeout(() => {    console.log(7);})// 此时微任务是then(data => {    console.log(data);})

执行一个微任务, 输出:6

3: 接着执行第一个宏任务

setTimeout(() => {    console.log(2);    Promise.resolve().then(() => {        console.log(3)    });});

输出:2

在此宏任务中,向任务 队列添加了一个微任务。此时任务队列有了新的微任务。

4:执行一个微任务,输出:3

then(() => {   console.log(3)});

5: 继续按照规则执行任务, 输出: 5、7

整体输出情况是:

6、2、3、5、7

到此,相信大家对“Javascript的Event Loop怎么实现”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Javascript的Event Loop怎么实现

本文链接: https://lsjlt.com/news/303145.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Javascript的Event Loop怎么实现
    本篇内容主要讲解“Javascript的Event Loop怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Javascript的Event Loop怎么实现”吧!一、...
    99+
    2023-06-22
  • javascript事件循环event loop的示例分析
    小编给大家分享一下javascript事件循环event loop的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!具体如下:js是单线程的,但是event loop的出现,使得js...
    99+
    2024-04-02
  • JavaScript 的setTimeout与事件循环机制event-loop
    目录1.先说说我们都知道的setTimeout2.再讲讲我们可能不知道的setTimeoutevent-loop3. node中的时间循环执行顺序4. 关于事件循环中的promise...
    99+
    2024-04-02
  • JS 中的 Event Loop 是什么你真的懂
    目录setTimeout 定时器并不准宏任务和微任务一道经典异步题结尾Event Loop,简单翻译就是 事件循环,是 JS 语言下实现运行时的一个机制。 JS 的异步并不...
    99+
    2024-04-02
  • JavaScript实现事件总线(Event Bus)的方法详解
    目录介绍原理分析进阶1. 如何在发送消息时传递参数2. 订阅后如何取消订阅3. 如何只订阅一次4. 如何清除某个事件或者所有事件5. TypeScript 版本6. 单例模式总结介绍...
    99+
    2024-04-02
  • python中Event怎么实现线程间同步
    这篇文章主要介绍“python中Event怎么实现线程间同步”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python中Event怎么实现线程间同步”文章能帮助大家解决问题。前言:Event在pyt...
    99+
    2023-06-29
  • Linux的loop循环怎么使用
    在Linux中,可以使用`for`循环和`while`循环来实现循环的功能。1. 使用`for`循环:```shellfor var...
    99+
    2023-09-22
    Linux
  • MySQL查看event执行记录的实现
    目录1. 查看 EVENT 执行记录2. 示例3. 结论mysql 是一款流行的关系型数据库管理系统,它提供了许多功能来帮助用户管理和操作数据库。其中之一就是 EVENT事件,它允许用户在特定的时间间隔内自动执行指定的操...
    99+
    2023-11-13
    MySQL查看event执行记录 MySQL查看event
  • javascript怎么实现ajax
    小编给大家分享一下javascript怎么实现ajax,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!javascript是一种什么语言javascript是一种动...
    99+
    2023-06-14
  • javascript的事件流怎么实现
    这篇文章主要讲解了“javascript的事件流怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript的事件流怎么实现”吧! ...
    99+
    2024-04-02
  • javascript是怎么实现继承的
    这篇文章将为大家详细讲解有关javascript是怎么实现继承的,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 方法:1、利用原型让一个引用类...
    99+
    2024-04-02
  • JavaScript的BOM操作怎么实现
    今天小编给大家分享一下JavaScript的BOM操作怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。window对象...
    99+
    2023-06-29
  • 怎么使用Node.js的内置模块event实现发布订阅模式
    这篇文章主要介绍了怎么使用Node.js的内置模块event实现发布订阅模式的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用Node.js的内置模块event实现发布订阅...
    99+
    2024-04-02
  • Javascript怎么实现继承
    这篇文章主要介绍“Javascript怎么实现继承”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Javascript怎么实现继承”文章能帮助大家解决问题。1、构造函...
    99+
    2024-04-02
  • javascript怎么实现下载
    这篇文章将为大家详细讲解有关javascript怎么实现下载,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 javascript实现下载的常用...
    99+
    2024-04-02
  • JavaScript继承怎么实现
    小编给大家分享一下JavaScript继承怎么实现,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!ES6之前,JavaScript...
    99+
    2024-04-02
  • javascript怎么实现加粗
    这篇文章主要介绍了javascript怎么实现加粗,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 javascr...
    99+
    2024-04-02
  • javascript怎么实现异步
    JavaScript是一门常用的编程语言,被广泛应用于web开发、游戏开发等领域。在JavaScript编程中,异步编程是一项重要的技术,它能够提高程序的性能和响应速度。那么,JavaScript怎样实现异步编程呢?本篇文章将从以下方面进行...
    99+
    2023-05-20
  • 怎么用Javascript实现Agent
    这篇文章主要为大家展示了“怎么用Javascript实现Agent”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么用Javascript实现Agent”这篇文章吧。既然是显示右键菜单,那么我们...
    99+
    2023-06-03
  • javascript重载怎么实现
    这篇文章主要讲解了“javascript重载怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript重载怎么实现”吧!首先,什么是重载?在其他一些编程语言中,重载指的是在同...
    99+
    2023-07-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作