首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

深入理解JS的事件循环

有了规则JS世界才能稳稳的运转起来,所以这些规则非常重要,但是你真的了解它们了吗? 阅读本文前可以思考下面几个问题: 你理解中的事件循环是怎样的? 有宏任务了,为什么还要有微任务,它们又有什么关系?...本文将会由浅入深的解答这些问题 深入理解JS系列 第一节:深入理解JS的深拷贝 第二节:深入理解JS的原型和原型链 第三节:深入理解JS的事件循环 万物初始 ★本文基于chromium内核讲解 ” 刚开始让万物运转是件挺容易的事情...现在的JS的事件循环系统就能持续运转起来啦: 循环机制解决了不能循环执行的问题:引入了循环机制,通过一个 while 循环语句,线程会一直循环执行 不过又有其他问题出现了: 别的线程要交给我这个主线程任务...从底层看setTimeout实现 到现在已经知道了,JS世界是由事件循环和任务队列来驱动的。 setTimeout大家都很熟悉,它是一个定时器,用来指定某个函数在多少毫秒后执行。...接下来分析一下: 调用ObjPromise传入一个函数命名为executor,executor函数接受两个参数resolve、reject,可以理解为分别代表成功时的调用和失败时的调用。

4K60

js执行栈与事件循环简单理解

JavaScript 是如何异步和单线程的,这个是大多数人知道的一句话,但是理解其真正原理的并不是太多.......肯定是第一个优先放到执行栈中的; console.log('A');是一个函数,虽然用得很多,但是确实是执行一个函数,想console控制台输出文本‘A’,在main函数没执行完时,他就被压入栈中,这很好理解...事件循环 所以,事件循环其实就是js代码借助与浏览器API向消息队列中丢入一些回调函数,等待执行栈放空自己的时候,把消息队列中的回调函数压入到执行栈中执行的这么一个机制。...紧接着runWhileLoopForNSeconds(3);被压入了执行栈中,是一个函数,由于js是单线程的,因此mian也好,runWhileLoopForNSeconds也好,都会在这个执行栈所在在执行上线文中孤独的执行着...总结 所以,只有当执行栈中是空的时候,事件循环机制才有机会把消息队列中的任务丢出来执行,换句话说,只有执行栈中有内容在执行,事件循环就不可能给你从消息队列中取任务出来执行。

1.6K30
您找到你想要的搜索结果了吗?
是的
没有找到

两个try catch引起的对JS事件循环的思考

为了能够接收用户的输入事件,我们可以写一个死循环来源源不断地读取用户的输入,比如每两个数字输入我们就计算它对应的和。...我们先来回顾下JS的异步编程模型,经过上面的介绍,我们应该已经非常熟悉事件循环系统了,我们把一些异步操作放进消息队列里来等待执行。...这里需要重点关注两个词:异步执行和隐式返回Promise。 关于异步执行的原因,我们一会儿再分析。这里我们先来看看是如何隐式返回Promise的。...解答第二个问题 讲了这么大一段,我们现在终于理解开头的第二个问题了。...结语 经过今天这么一通分析,想必目前JS的异步编程就难不倒大家了。

1K10

JS 循环链表

循环链表的概念循环链表是一种链表的变体,其中链表中的最后一个节点指向链表的头节点,形成一个循环或环状结构。与普通链表不同,循环链表没有明确的结束点。...循环链表具有以下几个特点:循环性:循环链表是通过将最后一个节点指向头节点来形成循环的闭合结构。这意味着链表中没有明确的结束点,可以从任何节点开始遍历整个链表,直到回到原始出发节点。...灵活性:由于循环链表是循环的,因此可以在任意位置插入或删除节点,而无需修改其他节点的指针。这使得循环链表在某些场景下更加灵活和高效,例如实现循环列表、轮播图等。...场景应用:循环链表常用于需要循环遍历的场景。例如,在游戏开发中,可以使用循环链表来实现循环列表,遍历玩家角色队列;在轮播图或循环播放的场景中,可以使用循环链表来管理展示内容的顺序。...实现一个循环列表在 JavaScript 中,循环链表是一种特殊的链表结构,其中最后一个节点指向头节点,形成一个循环。这种数据结构可以用于处理需要连续循环遍历的场景。

11710

js事件循环

首先,我们来解释下事件循环是个什么东西: 就我们所知,浏览器的js是单线程的,也就是说,在同一时刻,最多也只有一个代码段在执行,可是浏览器又能很好的处理异步请求,那么到底是为什么呢?...我们先来看一张图(这张图来自于http://www.zcfy.cc/article/node-js-at-scale-understanding-the-node-js-event-loop-risingstack...从上图我们可以看出,js主线程它是有一个执行栈的,所有的js代码都会在执行栈里运行。...其实(正如上图所示),js是有两个任务队列的,一个叫做Macrotask Queue(Task Queue),一个叫做Microtask Queue 前者主要是进行一些比较大型的工作,常见的有setTimeout...原因:因为一开始js主线程中跑的任务就是macrotask任务,而根据事件循环的流程,一次事件循环只会执行一个macrotask任务,因此,执行完主线程的代码后,它就去从microtask队列里取队首任务来执行

18.7K41

JS 事件循环

: 主线程:也就是 js 引擎执行的线程,这个线程只有一个,页面渲染、函数处理都在这个主线程上执行。...工作线程:也称幕后线程,这个线程可能存在于浏览器或js引擎内,与主线程是分开的,处理文件读取、网络请求等异步事件。...上述过程的不断重复就是我们说的 Event Loop (事件循环)。...在事件循环中,每进行一次循环操作称为tick,通过阅读规范可知,每一次 tick 的任务处理模型是比较复杂的,其关键的步骤可以总结如下: 在此次 tick 中选择最先进入队列的任务( oldest task...、process.nextTick(Node.js 环境) setTimeout/Promise 等API便是任务源,而进入任务队列的是由他们指定的具体执行任务。

15.4K10

理解 Python 中的 for 循环

>>> 9 in squares True >>> 9 in squares False 我们把一个问题问了两遍,但是 Python 给了两个不同的回答。...上面的代码很好的展现了 Python 中的循环是如何工作的。如果你理解了内置函数 iter 和 next 是如何作用于循环的,那么你就理解了 Python for 循环的工作方式。...事实上相比理解 for 循环的工作方式,你会了解的更多。所有循环都是这么工作的。 Iterator protocol(迭代器协议)描述了 Python 中循环的工作方式。...下面的代码用于计算一个序列中相邻两个数字的差,返回一个 list。...最后请记住,Python 中的每种类型的遍历都依赖于 iterator protocol,因此理解 iterator protocol 是了解 Python 中循环的关键。

5.1K10

深度理解NodeJS事件循环

导读ALL THE TIME,我们写的的大部分javascript代码都是在浏览器环境下编译运行的,因此可能我们对浏览器的事件循环机制了解比Node.JS的事件循环更深入一些,但是最近写开始深入NodeJS...学习的时候,发现NodeJS的事件循环机制和浏览器端有很大的区别,特此记录来深入的学习了下,以帮助自己及小伙伴们忘记后查阅及理解。...图片什么是事件循环首先我们需要了解一下最基础的一些东西,比如这个事件循环,事件循环是指Node.js执行非阻塞I/O操作,尽管==JavaScript是单线程的==,但由于大多数==内核都是多线程==的...LIBUV层: 是跨平台的底层封装,实现了 事件循环、文件操作等,是 Node.js 实现异步的核心 。...4. nextTick 与 Promise概念:对于这两个,我们可以把它们理解成一个微任务。也就是说,它其实不属于事件循环的一部分。那么他们是在什么时候执行呢?

93300
领券