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

深入理解JS事件循环

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

4K60

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

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

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

理解 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

关于for循环再次理解

for循环写法是1.5之后引入新 feature, 允许开发者用简明方式遍历一个数组中元素。...这种写法很符合人类思考方式,如果用 kotlin来写的话从语法上更贴合自然语言思维, for(str in sources) { .... } 翻译成自然语言的话, 就是"遍历 sources 中...关于 Iterator, 我们知道任何继承了 Collection类都需要默认实现一下 Iterator接口, 比如 hasNext(), next(), 从源码上来看的话,可以确定是 for循环也是通过迭代器来实现遍历..., 并且调用了 hasNext和 next方法, 确定了这一点之后就可以猜到,在源码级别的for循环会被编译器优化成下面这样 for(Iterator itr = source.iterator() ;..., javap是最简单直接理解方式。

54820

理解jsthis

为什么使用this 如果没有this,那么我们代码会是下面的写法: 在方法中,为了能够获取到name名称,必须通过obj引用(变量名称)来获取。...但是这样做有一个很大弊端:如果我将obj名称换成了info,那么所有的方法中obj都需要换成info。...(编写位置)没有关系; 3.this绑定和调用方式以及调用位置有关系; 4.this是在运行时被绑定; this绑定规则 默认绑定 在独立函数调用情况下使用默认绑定 独立函数调用我们可以理解成函数没有被绑定到某个对象上进行调用...: 也就是它调用位置中,是通过某个对象发起函数调用。...这个和setTimeout源码内部调用有关; setTimeout内部是通过apply进行绑定this对象,并且绑定是全局对象; 案例二:数组forEach 数组有一个高阶函数forEach,用于函数遍历

3K30

js事件循环

首先,我们来解释下事件循环是个什么东西: 就我们所知,浏览器js是单线程,也就是说,在同一时刻,最多也只有一个代码段在执行,可是浏览器又能很好处理异步请求,那么到底是为什么呢?...从上图我们可以看出,js主线程它是有一个执行栈,所有的js代码都会在执行栈里运行。...其实(正如上图所示),js是有两个任务队列,一个叫做Macrotask Queue(Task Queue),一个叫做Microtask Queue 前者主要是进行一些比较大型工作,常见有setTimeout...并执行,输出10,并且执行new Promise内函数(new Promise内函数是同步操作,并不是异步操作),输出11,并且将它两个then函数加入microtask队列 从microtask...原因:因为一开始js主线程中跑任务就是macrotask任务,而根据事件循环流程,一次事件循环只会执行一个macrotask任务,因此,执行完主线程代码后,它就去从microtask队列里取队首任务来执行

18.7K41

JS 循环链表

---导文循环链表是一种特殊链表数据结构,其中最后一个节点指向链表头节点,形成一个循环环状结构。与普通链表不同,循环链表没有明确结束点,可以通过任意节点开始遍历整个链表。...循环链表概念循环链表是一种链表变体,其中链表中最后一个节点指向链表头节点,形成一个循环或环状结构。与普通链表不同,循环链表没有明确结束点。...但是,在链接节点时需要特别注意将最后一个节点指针指向第一个节点,以形成循环闭合。循环链表应用场景包括游戏开发中循环列表、轮播图展示、约瑟夫环问题等。...场景应用:循环链表常用于需要循环遍历场景。例如,在游戏开发中,可以使用循环链表来实现循环列表,遍历玩家角色队列;在轮播图或循环播放场景中,可以使用循环链表来管理展示内容顺序。...注意环形链表处理:循环链表在操作时需要特别注意处理环形情况,以避免出现无限循环或死循环情况。在编程实现中,需要确保正确设置最后一个节点指针指向头节点。

11710

JS那些循环

一、forEach定义一个函数, 数组普通循环遍历, 并为每个数组元素执行一次传入callback/** * @param {*} element 当前处理元素 * @param {number}...js中除了上述三种循环之外, 还有一下循环方式 1、 for语句 2、 do...while语句 3、 while语句 4、 map函数 5、 some函数 6、 every函数以上不做详细介绍..., 下面一张表格对他们进行不同维度对比五、循环对比功能对比类型目标类型是否可中断返回值forEach函数数组否undefinedfor...in表达式非Symbol可枚举属性是无for...of表达式对可迭代对象是无...return arr7.push(value)})console.timeEnd('map');本地测试环境: node v16.14.2执行结果(耗时升序排列): 1、for: 254.181ms, 最简单循环方式.....of: 471.445ms, 通过访问对象迭代器进行循环6、map: 549.118ms, 会对数组进行浅拷贝, 并返回新数组, 耗时较长7、for...in: 2.222s, 耗时最长, 因为会访问到对象原型上

1.9K10

JS 事件循环

: 主线程:也就是 js 引擎执行线程,这个线程只有一个,页面渲染、函数处理都在这个主线程上执行。...工作线程:也称幕后线程,这个线程可能存在于浏览器或js引擎内,与主线程是分开,处理文件读取、网络请求等异步事件。...主线程内任务执行完毕为空,会去任务队列读取对应任务,推入主线程执行。 上述过程不断重复就是我们说 Event Loop (事件循环)。...在事件循环中,每进行一次循环操作称为tick,通过阅读规范可知,每一次 tick 任务处理模型是比较复杂,其关键步骤可以总结如下: 在此次 tick 中选择最先进入队列任务( oldest task...最后最后,记住,JavaScript 是一门单线程语言,异步操作都是放到事件循环队列里面,等待主执行栈来执行,并没有专门异步执行线程。

15.4K10

优化两个简单嵌套循环

优化嵌套循环方法通常取决于具体情况,但有几种常见技巧可以尝试。尽可能减少内部循环迭代次数,这可以通过更有效算法或数据结构来实现。...如果内部循环中使用值在外部循环中已经计算过,可以尝试在外部循环中计算并将结果存储起来,避免重复计算。...下面是一个简单示例,演示了如何通过优化来减少嵌套循环计算量:1、问题背景在优化以下两个嵌套循环时遇到了一些困难:def startbars(query_name, commodity_name):​...max(nc)在第一次循环后就是一个常量,因此可以将其移出循环以减少重复计算。重新组织数据结构。优化后代码使用了一个字典mapYearToWbcodeToField来存储数据,这使得查找更加高效。...同时使用了一个列表nc来存储所有值最大值,这样就可以在一次循环中计算出constant。

9310

jsDOM理解

try…catch try{}catch(e) {}finally{} Error.name六种值对应信息: 1. EvalError:eval()使用与定义不一致 2....URIError:URI处理函数使用不当 复制代码 es5严格模式 “use strict” 不再兼容es3一些不规则语法。使用全新es5规范。...DOM对象即为宿主对象, 由浏览器厂商定义,用来操作html和xml功能一类对象集合。 也有人称DOM是对HTML以及XML标准编程接口。...ie7以下版本中没有,非实时 .querySelectorAll() // css选择器 在ie7和ie7以下版本中没有,非实时 复制代码 DOM基本操作 遍历节点树: parentNode ->...->后一个兄弟节点 previousSibling->前一个兄弟节点 基于元素节点树遍历 parentElement -> 返回当前元素父元素节点 (IE不兼容) (以下IE不兼容指的是 9 以下)

4.2K30
领券