时间:2021-05-26
怎么判断是浏览器还是node环境?
node中window是未定义;setImmediate是定义的,在浏览器中未定义
timer阶段:这个阶段会执行setTimeout和setInterval
check阶段:执行setImmediate
macro task [task] 宏任务 :script(页面代码)、setTimeout、setInterval、I/O事件、UI交互事件(点击事件)
micro task [job] 微任务: Promise、process.nextTick、Promise().then()
宏任务可以有多个队列
微任务只有一个队列
setTimeout任务之间,推迟执行的毫秒数越小,排在队列里面越靠前
在node里面,timers(setTimeout、setInterval)会优先于setImmediate
setTimeout(() => { console.log('setTimeout')},0); // 大于1000时,会先执行setImmediatesetImmediate(()=> { console.log('setImmediate')})console.log('start');setTimeout(function (){ console.log('timeout');},10);new Promise((resolve) => { console.log('promise'); resolve() setTimeout(() => { console.log('Promsie中的setTimeout'); },0);}).then(() => { console.log('then');});console.log('end');运行机制
1. 在执行栈中执行一个宏任务。
2. 执行过程中遇到微任务,将微任务添加到微任务队列中。
3. 当前宏任务执行完毕,立即执行微任务队列中的任务。
4. 当前微任务队列中的任务执行完毕,检查渲染,GUI线程接管渲染。
5. 渲染完毕后,js线程接管,开启下一次事件循环,执行下一次宏任务(事件队列中取)。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
js异步解析一、js单线程分析我们都知道js的一大特点是单线程,也就是同一时间点,只能处理一件事,一句js代码。那为什么js要设计成单线程而不是多线程呢?这主要
一、js--->单线程 严格意义上来说,javascript没有多线程的概念,所有的程序都是单线程依次执行的。 1、什么是单线程? 通俗点说,就是代码在执
单线程的JS众所周知js是一门单线程语言,即同一时间只能做一件事。为什么js是单线程的呢,主要与它的用途有关。作为浏览器脚本语言,js的主要用途是和用户互动&操
Node.js采用事件驱动和异步I/O的方式,实现了一个单线程、高并发的运行时环境,而单线程就意味着同一时间只能做一件事,那么Node.js如何利用单线程来实现
相信不少人对Javascript单线程表示怀疑:为何单线程可以实现异步操作呢?其实Javascript确实是单线程的(我们不妨把这个线程称作主线程),但它实现异