怎么判断是浏览器还是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时,会先执行setImmediate setImmediate(()=> { 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线程接管,开启下一次事件循环,执行下一次宏任务(事件队列中取)。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“js单线程的本质 Event Loop解析”评论...
更新动态
2025年01月08日
2025年01月08日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]