NodeJS之Event Loop机制学习

这篇文章纯粹的是一篇学习性的自我理解的文章,内容不一定完全正确仅供参考。

之前看过一篇阮一峰大神写的Javascript运行机制之Event Loop详解,文章讲的通俗易懂,建议大家可以去他的博客看看。

1. NodeJS与Event Loop

NodeJS严格来说并不是一种独立的语言,它的主要作用是使得javascript这种客户端脚本语言可以运行在服务器端,这样JS(javascript简称)就与java、php、python等编程语言一样可以提供各种web服务。

NodeJS之所有能够在服务器端运行的主要原因要归功于Chrome的V8引擎,V8引擎就类似与php执行程序一样可以解析JS脚本并调用Node API,这样就达到了在服务器端运行JS脚本的目的。

单线程是JS的最大的特性也是与生俱来的,同时采用异步I/O以及事件驱动来提高执行效率。

那么具体是如何来做的呢,JS将所有的执行任何分为同步任务和异步任务两种,主线程执行的是同步任务,而异步任务则通过回调函数来与主线程进行交互,以达到与同步任务相同的效果。那么NodeJS理所当然的也继承了这样的特性:

2. 实例解析

function execTimer() {
    console.log("开始"); // 代码1
    // 代码3
    setTimeout(function() {
        console.log("这是计时器");
    }, 5000);
    console.log("结束"); // 代码2
}

execTimer();

// 执行结果
开始
结束
这是计时器

程序执行步骤:

  1. 先执行完代码1与代码2,同时将代码3丢到任务队列中;
  2. 循环读取任务队列直至找到代码3(时间到期),执行代码3;
JS的事件循环是指JS引擎在执行任务时的一种机制。在浏览器中,事件循环是由浏览器来实现的,而在NodeJS中也有自己的事件循环实现。事件循环的基本原理是将待处理的任务按顺序存放在一个任务队列中,然后从队列中取出任务并执行。在事件循环中,任务可以分为宏任务和微任务两种类型。宏任务包括整体的script代码、setTimeout、setInterval等,而微任务则包括Promise、MutationObserver等。在事件循环的执行过程中,微任务的执行优先于宏任务。 具体来说,事件循环的流程如下: 1. 执行当前的同步任务,即执行JS代码中的同步代码。 2. 检查是否存在微任务,如果存在,则按照先进先出的顺序依次执行微任务,直到微任务队列为空。 3. 当前的宏任务执行完成后,检查是否存在新的宏任务。如果存在,则执行下一个宏任务,否则继续等待新的任务加入队列。 4. 重复步骤2和步骤3,直到任务队列为空。 在NodeJS中,除了浏览器中的事件循环机制外,还有一些差异和新增的任务类型和任务阶段。具体来说,NodeJS的事件循环包括以下几个阶段: 1. timers阶段:执行定时器回调函数。 2. pending callbacks阶段:执行延迟到下一个循环迭代的I/O回调函数。 3. idle, prepare阶段:仅在内部使用。 4. poll阶段:检索新的I/O事件;执行I/O相关的回调函数。 5. check阶段:执行setImmediate()的回调函数。 6. close callbacks阶段:执行关闭的回调函数,如socket.on('close', ...)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值