2023一文搞懂Node的的事件循环

 所属分类:web前端开发

 浏览:244次-  评论: 0次-  更新时间:2023-04-14
描述:更多教程资料进入php教程获得。 本篇文章聊聊Nodejs中的事件循环,希望带大家搞懂Nodejs中的事件循环,从此再也不怕面试官的灵魂发问:谈一...
更多教程资料进入php教程获得。

本篇文章聊聊Nodejs中的事件循环,希望带大家搞懂Nodejs中的事件循环,从此再也不怕面试官的灵魂发问:谈一下Nodejs的事件循环!

想必大家面试的时候,都会被面试官问道:“谈谈Nodejs的事件循环吧”。

因为本人也被问道过,但每一次都很尴尬。

关于这个问题各种技术博客上有很多介绍,可我我一直都没有搞明白。因为这些文章往往上来就是一大堆图示、术语,瞬间浇灭了认知的勇气。【相关教程推荐:nodejs视频教程、编程教学】

但是不能不懂啊,面试官还要问,于是流着泪、咬着牙,参考了一些教程,有了自己的总结,马上分享给大家。

一、什么是事件循环?

一句话:事件循环是Nodejs处理异步操作的机制。

Js是单线程的,为什么Nodejs就能处理异步操作?

因为Nodejs把多线程的操作交给了系统内核。

上图:

Nodejs就像一个聪明的小孩,基于Js的它本身无法实现多线程操作,但是它把多线程的操作丢给了系统内核。

因为系统内核大部分都是多线程的,内核执行起来那不是so easy,那Nodejs就高枕无忧了嘛?

二、为什么需要事件循环?

(先解释一下事件循环这个名称,Nodejs是事件驱动的,当什么时候 做什么事情,做的事情就定义在回调函数中;

因此可以将回调函数定义为事件处理函数;所以管理回调函数的机制叫做事件循环;)

既然内核那么强大,Nodejs无事一身轻?

非也,内核执行完毕之后,Nodejs总得执行对应的回调函数吧。

所以就需要一个机制帮助它管理、维护这些异步操作回调函数,防止它们打架啊、乱串啊。

从而以一种高效的方式执行。所以这就是为什么需要---事件循环---。

总结:事件循环是Nodejs用来控制异步代码回调执行顺序的!

三、怎样理解事件循环?

? 口诀一:同步任务总是比异步任务执行更早;

异步API分类

同步任务无需多言,这里先将Nodejs中的异步API进行分类:

简单理解,针对上述三种异步API,事件循环内部提供了3种队列,

奇怪?为什么没有process.nectTick?

哈哈,那是因为process.nectTick本身就很奇怪!

process.nectTick

虽然process.nectTick属于异步API,但是却不属于事件循环的一部分。

上图:

这里就牵涉到另一个概念:异步模块!

异步模块

就是这个神奇的家伙,nodejs使用libuv库调用内核,实现多线程的操作!

那这个跟process.nectTick有几毛钱关系?

有,因为process.nectTick可以理解为异步模块的一部分。

因此,process.nectTick总会在事件循环之前被调用!

? 口诀二:process.nectTick是所有异步任务里面最快执行的;

(注:理解Tick

事件循环3种队列运行一周,成为一个Tick!)

好,明白了!

等等......好像还缺少了什么?Promise又是怎么执行的?

Promise

除了nextTick队列,还有一种特殊的队列:微任务队列。微任务队列,主要就是用来处理Promise回调函数的执行。

那微任务队列的执行顺序又是怎样的呢?

上图:

? 口诀三:微任务队列追加在process.nectTick队列后面,事件循环的前面;

上面讲了这么多,整体看下

? 口诀四:实践出真知;

利用上面的理论,聪明的你,能分析一下最终的打印顺序嘛?

console.log('同步代码')setImmediate(() => {    console.log('setImmediate');})setTimeout(() => {    console.log('setTimeout');}, 100)Promise.resolve().then(() => {    console.log('promise');})process.nextTick(() => {    console.log('Tick');})复制代码
登录后复制

那下次我们就结合具体的面试案例,看看它们的打印顺序到底是怎样。

更多node相关知识,请访问:nodejs 教程!

以上就是一文搞懂Node的的事件循环的详细内容,更多请关注zzsucai.com其它相关文章!

 标签: 后端,Node.js,
积分说明:注册即送10金币,每日签到可获得更多金币,成为VIP会员可免金币下载! 充值积分充值会员更多说明»

讨论这个素材(0)回答他人问题或分享使用心得奖励金币

〒_〒 居然一个评论都没有……

表情  文明上网,理性发言!