分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > IT知识

js-EventLoop

发布时间:2023-09-06 01:56责任编辑:郭大石关键词:js

1、浏览器事件环

eventLoop是由js的宿主环境(浏览器)来实现的

事件循环可以简单的描述为以下四个步骤

1、函数入栈,当Stack中执行到异步任务的时候,就将他丢给WebAPIs,接着执行同步任务,直到Stack为空

2、此期间WebAPIs完成这个事件,把回调函数放入队列中等待执行(微任务放到微任务队列,宏任务放到宏任务队列)

3、执行栈为空时,Event Loop把微任务队列执行清空;

4、微任务队列清空后,进入宏任务队列,取队列的第一项任务放入Stack(栈)中执行,回到第一步。

2、认识浏览器中的任务源

(1)微任务:then、messageChannel、mutationObersve

(2)宏任务:setTimeout 、setInterval、setTmmediate(只兼容ie)

3、node环境中的事件环

  • 图虽然有些乱,但是我们只需关心timers计时器阶段和poll轮询阶段,check检查阶段即可,clons关闭阶段以及微任务队列即可。

  • Node 环境中微任务是插缝执行,(如果执行宏任务的时候发现了微任务, 不会像浏览器一样执行了,而是将为微任务放到微任务队列中,等待整个宏 任务队列执行完毕或者达到执行上线后,下一个阶段开始的时候先执行 完微任务队列中的任务)。

  1. 认识Node中的任务源(task):
  • 微任务: then 、nextTick 、 messageChannel 、mutationObersve
  • 宏任务:setTimeout 、setInterval 、setImmediate 、io文件操作
  1. 例一:timeout、immediate 两个谁先执行不一定 取决于node的执行时间。
setTimeout(function () { ???console.log(‘setTimeout1‘);})setImmediate(function () { ???console.log(‘setImmediate2‘);});
打印结果有两种:
  • 1) setTimeout1 setImmediate2
  • 2) setImmediate2 setTimeout1
  1. 例二: 如果i/o文件操作以后就会先执行setImmediate,因为setImmediate在i/o文件操作后面的那个阶段执行,执行完setImmediate会在下一个阶段的时候再执行setTimeout (timers 计时器执行阶段)
let fs = require(‘fs‘);fs.readFile(‘1.log‘, function () { ?console.log(‘fs‘); ?setTimeout(function () { ???console.log(‘timeout‘); ?}); ?setImmediate(function () { ???console.log(‘mmiediate‘); ?});});
打印顺序结果
  • fs 、 miediate、 timeout
  1. 例三: 微任务中nextTIck 会比then先执行。
Promise.resolve().then(function () { ?console.log(‘then2‘):});process.nextTick(function () { ?console.log(‘nextTick1‘);});
打印顺序结果
  • nextTick1 then2
  1. 例四: 微任务会优先与i\o文件操作执行。
let fs = require(‘fs‘);fs.readFile(‘./1/log‘,function(){ ???console.log(‘fs‘)})process.nextTick(function(){ ???console.log(‘text2‘);})
打印执行结果
  • text2 fs

js-EventLoop

原文地址:https://www.cnblogs.com/yyxh/p/9089998.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved