Node.js的Event Loop详解

这次给大家带来node.js的event loop详解,使用node.js的event loop注意事项有哪些,下面就是实战案例,一起来看一下。

Node.js也是单线程的Event Loop,但是它的运行机制不同于浏览器环境。

请看下面的示意图

QQ截图20180316153315.png

根据上图,Node.js的运行机制如下。

(1)V8引擎解析JavaScript脚本。

(2)解析后的代码,调用Node API。

(3)libuv库负责Node API的执行。它将不同的任务分配给不同的线程,形成一个Event Loop(事件循环),以异步的方式将任务的执行结果返回给V8引擎。

(4)V8引擎再将结果返回给用户。

除了setTimeout和setInterval这两个方法,Node.js还提供了另外两个与”任务队列”有关的方法:process.nextTick和setImmediate。它们可以帮助我们加深对”任务队列”的理解。

process.nextTick方法可以在当前”执行栈”的尾部—-下一次Event Loop(主线程读取”任务队列”)之前—-触发回调函数。也就是说,它指定的任务总是发生在所有异步任务之前。setImmediate方法则是在当前”任务队列”的尾部添加事件,也就是说,它指定的任务总是在下一次Event Loop时执行,这与setTimeout(fn, 0)很像。请看下面的例子(via StackOverflow)。

process.nextTick(function A() {  console.log(1);  process.nextTick(function B(){console.log(2);});});setTimeout(function timeout() {  console.log('TIMEOUT FIRED');}, 0)// 1// 2// TIMEOUT FIRED

登录后复制

上面代码中,由于process.nextTick方法指定的回调函数,总是在当前”执行栈”的尾部触发,所以不仅函数A比setTimeout指定的回调函数timeout先执行,而且函数B也比timeout先执行。这说明,如果有多个process.nextTick语句(不管它们是否嵌套),将全部在当前”执行栈”执行。

现在,再看setImmediate。

setImmediate(function A() {  console.log(1);  setImmediate(function B(){console.log(2);});});setTimeout(function timeout() {  console.log('TIMEOUT FIRED');}, 0);

登录后复制

上面代码中,setImmediate与setTimeout(fn,0)各自添加了一个回调函数A和timeout,都是在下一次Event Loop触发。那么,哪个回调函数先执行呢?答案是不确定。运行结果可能是1–TIMEOUT FIRED–2,也可能是TIMEOUT FIRED–1–2。

令人困惑的是,Node.js文档中称,setImmediate指定的回调函数,总是排在setTimeout前面。实际上,这种情况只发生在递归调用的时候。

setImmediate(function (){  setImmediate(function A() {    console.log(1);    setImmediate(function B(){console.log(2);});  });  setTimeout(function timeout() {    console.log('TIMEOUT FIRED');  }, 0);});// 1// TIMEOUT FIRED// 2

登录后复制

上面代码中,setImmediate和setTimeout被封装在一个setImmediate里面,它的运行结果总是1–TIMEOUT FIRED–2,这时函数A一定在timeout前面触发。至于2排在TIMEOUT FIRED的后面(即函数B在timeout后面触发),是因为setImmediate总是将事件注册到下一轮Event Loop,所以函数A和timeout是在同一轮Loop执行,而函数B在下一轮Loop执行。

我们由此得到了process.nextTick和setImmediate的一个重要区别:多个process.nextTick语句总是在当前”执行栈”一次执行完,多个setImmediate可能则需要多次loop才能执行完。事实上,这正是Node.js 10.0版添加setImmediate方法的原因,否则像下面这样的递归调用process.nextTick,将会没完没了,主线程根本不会去读取”事件队列”!

process.nextTick(function foo() {  process.nextTick(foo);});

登录后复制

事实上,现在要是你写出递归的process.nextTick,Node.js会抛出一个警告,要求你改成setImmediate。

另外,由于process.nextTick指定的回调函数是在本次”事件循环”触发,而setImmediate指定的是在下次”事件循环”触发,所以很显然,前者总是比后者发生得早,而且执行效率也高(因为不用检查”任务队列”)。

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

JavaScript的定时器详解

JavaScript运行机制之事件和回调函数

浏览器的多线程机制详解

关于js中类型转换的一些小问题

以上就是Node.js的Event Loop详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2781852.html

(0)
上一篇 2025年3月8日 16:23:37
下一篇 2025年3月8日 16:23:43

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JS的Arrary方法

    这次给大家带来js的arrary方法,使用js的arrary方法注意事项有哪些,下面就是实战案例,一起来看一下。 栈方法: js提供了两个方法,来实现类似栈的操作: push()、pop() 栈是一种LIFO(last in first o…

    编程技术 2025年3月8日
    200
  • 判断日期是否有效的JavaScript代码段

    这次给大家带来判断日期是否有效的javascript代码段,用javascript判断日期是否有效的注意事项有哪些,下面就是实战案例,一起来看一下。 JavaScript正变得越来越流行,它已经成为前端开发的第一选择,并且利用基于JavaS…

    编程技术 2025年3月8日
    200
  • JS匀速运动实例详解

    本文主要和大家分享JS匀速运动实例详解,希望能帮助到大家,我们先和大家介绍JS运动的基本原理。 JS运动的基本原理: 让p运动起来,关键是修改物体的坐标, op.style.left=offsetLeft+speed+’px’; 登录后复制…

    2025年3月8日
    200
  • 使文本高亮的JavaScript代码

    这次给大家带来使文本高亮的javascript代码,用javascript使文本高亮的的注意事项有哪些,下面就是实战案例,一起来看一下。 有很多JQuery的第三方库可以实现高亮文本的功能,但我更喜欢用下面这一小段JavaScript代码来…

    编程技术 2025年3月8日
    200
  • 使文字动效的JavaScript代码

    这次给大家带来使文字动效的javascript代码,用javascript代码使文字动效的注意事项有哪些,下面就是实战案例,一起来看一下。 有时你会希望给你的一段文字增加动效,让其中的每个字都动起来。你可以使用下面这段jQuery插件代码来…

    编程技术 2025年3月8日
    200
  • 逐个隐藏元素的JavaScript代码

    这次给大家带来逐个隐藏元素的javascript代码,使用javascript代码逐个隐藏元素的注意事项有哪些,下面就是实战案例,一起来看一下。 下面这个jQuery插件可以根据你设置的步长(间隔时间)来逐个隐藏一组元素。在列表元素的重新加…

    编程技术 2025年3月8日
    200
  • angularjs如何导出Excel实例分享

    本文主要和大家分享angularjs如何导出Excel实例,希望能帮助到大家。 angularjs 1.x导出excel方法,常用的有2种 1. 直接导出table为xls service中加入 homeServiceMoudule.fac…

    2025年3月8日
    200
  • js归并算法实例详解

    本文主要和大家分享js归并算法实例详解,希望能帮助到大家。 将数组递归分裂成单个元素  然后合并数组 let data3 = [14, 54, 73, 38, 39, 67, 75, 80, 50, 40, 96, 27, 105, 109…

    编程技术 2025年3月8日
    200
  • 完全掌握js回调函数

    一、前奏 在谈回调函数之前,先看下下面两段代码: 不妨猜测一下代码的结果。 function say (value) {    alert(value);}alert(say);alert(say(‘hi js.’)); 登录后复制 如果你…

    2025年3月8日
    200
  • 限制文本字数的JavaScript代码

    这次给大家带来限制文本字数的javascript代码,使用javascript代码的限制文本字数的注意事项有哪些,下面就是实战案例,一起来看一下。 下面这端脚本允许你根据给定的字符长度截取文本,如果文本被截取,那么它的后面会自动带上省略号。…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论