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

Promise、setTimeout的执行顺序

同步和异步任务 ​ 要了解异步线程我们首先应该明白它的用处,因为js的单线程特性,任务的执行顺序都是依次执行,而当我们在工作中遇到网络请求,前后端交互的时候,你的数据不会马上拿到,这需要时间,如果等拿到数据再执行下面的代码...-同步任务进入主线程,按顺序从上而下依次执行, -异步任务,进入`event table` ,注册回调函数 `callback` , 任务完成后,将`callback`移入`event queue`中等待主线程调用...1.3.4.2 ,我们首先找到同步任务,1 3 是同步任务,然后执行异步任务,异步任务如果按顺序执行则是24 但是答案是4.2那么我们可以知道 promise执行顺序优先于setTimeout所以由此可知...红线就是任务的执行顺序 黑线是任务的结构 看完这么多下面来完成下面这道题并加以分析: console.log(1) setTimeout(() => { console.log(2) new...微任务, 直接执行 new Promise 输出 5, 并将 then 函数的回调函数推入 micro Task 的 event queue 中, micro Task 的 event queue 中记

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

多层嵌套 promise then 执行顺序

在看 js 事件循环的时候,看到一个有趣的 promise then 执行顺序的题,想了好久,终于想明白了,这里记录一下。 大家先想下这里的执行顺序是什么。...,这里首先要明确一点  promise then函数回调执行完毕后才会开始下一个 then 函数,当多个 then 链式调用的时候,如果一个 then 函数放入微任务队列,没有执行完,则之后的 then...首先,大家都知道 setTimeout 是宏任务,则一定在下一轮事件循环的时候才执行,则他的执行优先级最低,promise是同步任务,会先执行promise.then() 是微任务,当遇到微任务的时候...,接下来没有同步任务了,开始执行微任务队列,当执行到 23 行的时候,这个微任务先执行 promise 同步函数,将then 444 又放入了 微任务队列,接下来没有课执行的同步任务了,则开始执行微任务队列...22-34 行执行结束: 进入下一个宏任务,执行第 3 行,同步任务,打印 666,执行 4-5 行,同步任务,进入 then,执行 7 行,微任务。

1.1K40

settimeout(fn 0)与Promise执行顺序

这里涉及到三个“何时”: setTimeout(fn, 0)何时执行 promise函数何时执行 then何时执行 下面我们来一一分析。 1. setTimeout(fn, 0)何时执行?...而settimeout(fn, 0)表示立即执行,也就是用来改变任务的执行顺序,要求浏览器”尽可能快“的进行回调。 2. promise何时执行?...新建后立即执行,也就是说,Promise构造函数里的代码是同步执行的。...接着, 会先执行 macrotask 中的第一个任务(整个 script中的同步代码 ),再加上promise 构造函数也是同步的(promise.then 回调被推进到 microtask 队列中),...所以会先打印出2 10 3,然后继续执行末尾的,打印出5 此时,已经执行完了第一个 macrotask , 所以接下来会顺序执行所有的 microtask, 也就是 promise.then 的回调函数

1.3K30

promise执行顺序面试题令我头秃

red 函数,2秒执行一次 green 函数,1秒执行一次 yellow 函数,不断交替重复亮灯,意思就是按照这个顺序一直执行这3个函数,这步可以就利用递归来实现。...; }).then(function () { step(); });}step();参考 前端进阶面试题详细解答题目五实现 mergePromise 函数,把传进去的数组按顺序先后执行...Promise,按题目的要求我们只要顺序执行这三个函数就好了,然后把结果放到 data 中,但是这些函数里都是异步操作,想要按顺序执行,然后输出 1,2,3并没有那么简单,看个例子。...function B() { setTimeout(function () { console.log('b'); }, 1000);}A();B();// b// a例子中我们是按顺序执行的...A,B 但是输出的结果却是 b,a 对于这些异步函数来说,并不会按顺序执行完一个,再执行后一个。

50820

Js篇-面试题2-Promise 执行顺序问题

Promise 执行问题 写出下面一段程序的输出的结果 new Promise(resolve => { console.log(1); setTimeout(() => console.log...(2),0) Promise.resolve().then(() => console.log(3)) resolve(); }).then(() => console.log(4))...console.log(5) 答案: 1 5 3 4 2 解析:事件循环,任务队列的执行顺序,new Promise是会立即调用,接收了一个resolve参数,执行调用输出console.log(1)...语句,遇到setTimeout,它是一个异步宏任务,会推送到任务队列中,进入挂起状态 而promise.resove也是一个异步微任务,仍然会推送到任务队列中,进入挂起状态,当主线程console.log...(5)执行完后,在从异步任务队列中进行执行,在同一栈中,微任务要优先于宏任务的执行,所以先执行 3,然后 4,最后是 2 最终执行顺序结果是:1,5,3,4,2

1.3K10

【微信小程序】---- Promise.then(success, fail)执行顺序的问题

错误分析 设置默认地址成功,获取地址列表成功; 设置默认地址和获取地址列表同时执行; 按照第2步中,需要的是设置默认成功后执行获取地址列表; 通过分析,在执行成功函数,获取地址列表出现错误!...appKey, token }).then(this.getAddressList.bind(this)) 通过代码对比,区别就在call和bind的区别; call是绑定this并执行...;bind是绑定this返回函数,不执行!...Promise.then这里应该传入的是地址列表这个函数,在成功后执行这个函数,而不是执行结果! 6. 总结 设置成功后的回调,执行的是函数!函数!函数!; 传给成功函数的是函数!函数!函数!!

1.3K20

promise执行顺序面试题令我头秃,你能作对几道

red 函数,2秒执行一次 green 函数,1秒执行一次 yellow 函数,不断交替重复亮灯,意思就是按照这个顺序一直执行这3个函数,这步可以就利用递归来实现。...(1000, yellow); }).then(function () { step(); });}step();题目五实现 mergePromise 函数,把传进去的数组按顺序先后执行...Promise,按题目的要求我们只要顺序执行这三个函数就好了,然后把结果放到 data 中,但是这些函数里都是异步操作,想要按顺序执行,然后输出 1,2,3并没有那么简单,看个例子。...function B() { setTimeout(function () { console.log('b'); }, 1000);}A();B();// b// a例子中我们是按顺序执行的...A,B 但是输出的结果却是 b,a 对于这些异步函数来说,并不会按顺序执行完一个,再执行后一个。

39920

Python - 执行顺序执行入口

Python 是如何执行的?执行顺序是怎么样? 至上而下,逐行执行 #!...什么是 Python 脚本的执行入口 类比:进入一栋大楼肯定有个大门入口,赛车要进入赛道也一定有一个入口 所以,执行程序,也需要一个入口 一般称代码执行的入口叫做主函数(main 函数) 执行入口(主函数...假设运行的是 xiaoming.py,那么就会执行主函数 假设运行的是 xiaohong.py,即使 xiaohong 导入了 xiaoming,也不会执行 xiaoming.py 里面的主函数(main...函数) 是否一定需要执行入口(主函数) 不一定 假设没有主函数,那么运行 xiaoming.py 时,就会至上而下,逐行运行 xiaoming.py 的所有代码 执行入口的意义 将业务代码写在主函数上面...,主函数用来调用有业务代码,代码结构整洁 向 Java、C、Golang 看齐,他们都是要求一个程序必须有一个主执行入口才能正确运行

1.8K40

JS执行顺序

javascript给人的直观感受是,从上往下执行,但实际上却不是这样的,先看个例子 1. console.log(test); 2. var test = "你好"; 3. console.log(...因为javascript执行时,在同一个作用域内是先编译再执行 编译的时候会编译 function 和 var 这两个关键词定义的变量,编译完成后从上往下执行并向变量赋值 所以执行第1行时, var test...已经执行过了,所以test不会报错,而test2就会报错 需要注意的是,对 var test 执行编译时,只是先定义了 test 这个变量,并不会把 "你好" 这个值赋给test,而是到第2行时才给test...赋值的,这就是为什么第1行的执行结果是 undefined 对于上面的例子,可以这样理解 //先编译 var 定义的变量 1. var test; //编译完成后,从上到下执行代码 2. console.log...//执行结果是"你好" function test() { console.log("你好"); } 模拟编译执行过程 //找到 function 定义的部分进行编译 //以函数名作为变量名,同时用函数赋值

9.2K60

线程顺序执行

package com.wwj.javabase.thread.order; /** * @author wwj * 通过子程序join使线程按顺序执行 */ public class ThreadJoinDemo...package com.wwj.javabase.thread.order; /** * @author wwj * 通过主程序join使线程按顺序执行 */ public class ThreadMainJoinDemo...应用场景:串行执行所有任务。如果这个唯一的线程因为异常结束,那么会有一个新的线程来替代它。此线程池保证所有任务的执行顺序按照任务的提交顺序执行。...早上: 测试人员来上班了… 产品经理来上班了… 开发人员来上班了… 产品经理规划新需求 开发人员开发新需求功能 测试人员测试新功能 — 7 — 使用 CyclicBarrier (回环栅栏)实现线程按顺序执行...运行结果 早上: 测试人员来上班了… 产品经理来上班了… 开发人员来上班了… 产品经理规划新需求 开发人员开发新需求功能 测试人员测试新功能 — 8 — 使用线程的 Sephmore(信号量) 实现线程按顺序执行

2.9K30

postman脚本执行顺序

单一请求中脚本的执行顺序 单一请求中,我们可以设置pre-request, test两个脚本。 其执行顺序如下图所示: ? pre-request脚本 发送请求, 收到响应 test脚本 二....这种情况下脚本们的执行顺序是怎么样的呢? 脚本执行顺序如下图所示: ?...集合pre-request 文件集pre-request 请求中的pre-request 发送请求, 收到响应 集合test 文件夹test 请求中的test 注意: 每个请求都会按上面的流程执行。...也就是说如果有n个请求,集合和文件夹中的脚本就会执行n次。 三. 一个例子 假设我们在study集合的demo文件夹下有request1, request2两个请求。 ?...console.log("folder pre-reqeust"); test: console.log("folder test"); 然后在请求上加入与上面类似的pre-request和test 最后执行

1.5K20
领券