首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

nodejs事件循环

2019-04-04 06:21:40 js的执行是事件循环模型,同样作为服务端的nodejs也是基于事件循环的事件模型,但是他又增加了一些非 IO 的异步 API: setTimeOut(), setInterval...nodejs事件循环 首先,我们需要了解node.js的基于事件循环的事件模型,正是因为它才使得node.js中回调函数十分普遍,也正是基于此,node.js实现了单线程高效的异步IO(这里说的单线程主要说的是执行...同步任务进入主线程后会一直执行,直到同步任务执行完毕,主线程才会出现空闲,此时会去事件队列中查找是否有可执行的异步任务,如果有就推入到主线程中开始执行。如此就完成了整个事件循环。...nodejs在启动时,他会创建一个类似于while(true)的结构,每次执行一次循环体称为一次tick,每个tick的过程就是查看是否有事件等待处理,如果有,则取出事件极其相关的回调函数并执行,然后执行下一次...在每个tick中,如何判断是否有事件需要处理,于是引入了观察者的概念。每一个事件循环都有一个或多个观察者,判断是否有事件需要执行的过程其实就是想这些观察者询问是否有需要处理的事件

98240

nodejs事件循环

6个主要阶段 当js同步脚本运行完后,如果有异步操作还没有完成,node就将进入事件循环,像http.createServer.listen,fs.readFileAsync等操作都会使node进入事件循环...,适当时候,Node将在这里堵塞 5.cheak setImmediate的回调在此执行 6.close callback 关闭的回调,close事件的监听回调 重点解释 1.poll阶段 主要任务...不会等待响应的I/O回调,如果没有setImmediate设置的回调队列,就会等待I/O操作 举个例子 比如有一个设置了100ms后执行的定时器,同时有一个I/O操作,交给内核,内核正在读取文件,当事件循环开始时...,timers阶段显示时间没到100ms,跳过进入poll阶段,此时文件还没有读完,但因为poll阶段检测到也没到定时器的100ms,所以即使进行下一轮的事件循环还是会跳过timers阶段,所以决定等待文件读取的操作...,就是堵塞在poll阶段,直到100ms,此时如果文件读取完成,就会把文件读取的回调执行完,再进入下一轮事件循环,执行timers的定时器 但有一个情况会有所不同,就是在cheak阶段的队列不为空,即有

44030
您找到你想要的搜索结果了吗?
是的
没有找到

nodejs事件事件循环详解

简介 上篇文章我们简单的介绍了nodejs中的事件event和事件循环event loop。...nodejs中的事件循环 虽然nodejs是单线程的,但是nodejs可以将操作委托给系统内核,系统内核在后台处理这些任务,当任务完成之后,通知nodejs,从而触发nodejs中的callback方法...通过这样的event loop设计,nodejs最终可以实现非阻塞的IO。 nodejs中的event loop被分成了一个个的phase,下图列出了各个phase的执行顺序: ?...close callbacks 最后一个phase是处理close事件中的callbacks。比如一个socket突然被关闭,那么将会触发一个close事件,并调用相关的callback。...这里实际上就用到了process.nextTick技术,从而不管我们在什么地方绑定listening事件,都可以监听到listen事件

69431

nodejs事件事件循环详解

简介 上篇文章我们简单的介绍了nodejs中的事件event和事件循环event loop。...nodejs中的事件循环 虽然nodejs是单线程的,但是nodejs可以将操作委托给系统内核,系统内核在后台处理这些任务,当任务完成之后,通知nodejs,从而触发nodejs中的callback方法...poll轮询 poll将会检测新的I/O事件,并执行与I / O相关的回调,注意这里的回调指的是除了关闭callback,timers,和setImmediate之外的几乎所有的callback事件。...close callbacks 最后一个phase是处理close事件中的callbacks。 比如一个socket突然被关闭,那么将会触发一个close事件,并调用相关的callback。...这里实际上就用到了process.nextTick技术,从而不管我们在什么地方绑定listening事件,都可以监听到listen事件

80940

深度理解NodeJS事件循环

导读ALL THE TIME,我们写的的大部分javascript代码都是在浏览器环境下编译运行的,因此可能我们对浏览器的事件循环机制了解比Node.JS的事件循环更深入一些,但是最近写开始深入NodeJS...学习的时候,发现NodeJS事件循环机制和浏览器端有很大的区别,特此记录来深入的学习了下,以帮助自己及小伙伴们忘记后查阅及理解。...,在1000s后才会放入事件2.事件循环进入到poll阶段,开始不断的轮询监听事件3.fs模块异步执行,根据文件大小,可能执行时间长短不同,这里我使用的小文件,事件大概在9s左右4.setImmediate...,所以事件循环有一次进入到poll阶段,进行轮询6.读取文件完毕,fs产生了一个事件进入到poll阶段的事件队列,此时事件队列准备执行callback,所以会打印(read time: 9),人工阻塞了...有给人一种插队的感觉.setImmediate 的回调处于check阶段, 当poll阶段的队列为空, 且check阶段的事件队列存在的时候,切换到check阶段执行,参考nodejs进阶视频讲解:进入学习

93800

彻底搞懂nodejs事件循环

nodejs是单线程执行的,同时它又是基于事件驱动的非阻塞IO编程模型。这就使得我们不用等待异步操作结果返回,就可以继续往下执行代码。当异步事件触发之后,就会通知主线程,主线程执行相应事件的回调。...今天我们从源码入手,分析一下nodejs事件循环机制。...nodejs架构首先,我们先看下nodejs架构,下图所示:图片如上图所示,nodejs自上而下分为用户代码 ( js 代码 )用户代码即我们编写的应用程序代码、npm包、nodejs内置的js模块等,...6、创建一个nodejs运行实例。7、启动上一步创建好的实例。8、开始执行js文件,同步代码执行完毕后,进入事件循环。9、在没有任何可监听的事件时,销毁 nodejs 实例,程序执行完毕。...以上就是 nodejs 执行一个js文件的全过程。接下来着重介绍第八个步骤,事件循环。我们看几处关键源码:1、core.c,事件循环运行的核心文件。

1K20

Nodejs 发送 TCP 消息的正确姿势

于是就花了点时间研究了下用 Nodejs发送 TCP 消息。 问题 上面说了使用内建的节点“tcp-out”发送 TCP 消息会有问题。那么到底是什么问题呢?...“tcp-out” 节点只是简单的把 payload 字符串转成了 buffer 然后发送了出去。其实如果自己做测试,发送一个消息然后服务端接受一个消息一点问题都没有的。...使用 Nodejs 发送 TCP 报文(消息) 好了上面铺垫了这么多 ,总算要开始写代码了。 如果你打开 Google 搜索 "nodejs 发送 tcp" 你会得到很多代码示例。...简单说一下就是,在发送 payload 之前,需要先分配一个 4 字节长度的 buffer,然后写入整个消息的长度,发送出去,紧接着发送真正的 payload 。...这样就完成了一次 TCP 报文消息的发送。 总结 虽然题目叫 Nodejs 发送消息,但是代码却是寥寥几行。本文多数文字都是在描述 TCP 协议相关的东西。

1.4K30

nodejs事件处理机制

类似于javascript客户端代码中存在由元素触发的事件机制,在nodejs中,也有由对象触发的事件处理机制,比如http.Server对象,就可能会触发'接收到客户端请求request'、'响应客户端请求...nodejs中常用的内置模块主要有http、os、path、fs、events、stream等,其中event模块就是用来实现各种事件处理机制的。...在学习event模块实现事件处理机制前,首先回顾下nodejs模块的引入。在nodejs中,可以直接使用require函数并将模块名设置为require函数的参数值的方法来引用模块。...说回主线nodejs事件处理机制。...在nodejs的用于实现各种事件处理的event模块中,定义了一个EventEmitter类,所有可能触发事件的对象都是一个继承了EventEmitter类的子类的实例对象,EventEmitter类中定义好了许多方法

68530

nodejs事件循环分析

在上一篇文章在chromev8中的JavaScript事件循环分析中分析到,在chrome中的js引擎是通过执行栈和事件队列的形式来完成js的异步操作。...事件循环 当 Node.js 启动时,它将初始化事件循环机制,处理提供的输入脚本,该脚本可能会进行异步 API 调用、计划计时器或调用,然后开始处理事件循环。...当队列已用尽或达到回调限制时,事件循环将进入下一阶段,依此类推。 由于这些操作中的任何一个都可能计划更多操作,并且轮询阶段处理的新事件由内核排队,因此可以在处理轮询事件时对轮询事件进行排队。...prepare-poll-check-close callbacks完成一个执行周期,其中的poll用来处理异步操作 参考资料 https://zhuanlan.zhihu.com/p/33058983 http://nodejs.cn.../learn/the-nodejs-event-loop https://nodejs.org/en/docs/guides/event-loop-timers-and-nexttick/

3.9K00

Nodejs学习笔记(二)--- 事件模块

简介及资料 http://nodejs.org/api/events.html http://www.infoq.com/cn/articles/tyq-nodejs-event events是node.js...与DOM树上事件不同,不存在事件冒泡、逐层捕获等行为。 EventEmitter 支持若干个事件监听器。当事件发射时,注册到这个事件事件监听器被依次调用,事件参数作为回调函数参数传递。      ... emitter.removeAllListeners传用事件名作为参数时,为移除传入事件名的所有监听,而不会影响其它事件监听!...emitter.setMaxListeners(n) 一个事件可以添加多个监听是没错,但Nodejs默认最大值是多少呢? ?...事件的继承 以后归到util里再讲一下吧,有兴趣的可以自已看看 http://nodejs.org/api/util.html#util_util_inherits_constructor_superconstructor

1.1K80

nodejs事件处理机制以及事件环机制

nodejs事件处理机制以及事件环机制 ES6标准发布后,module成为标准,标准的使用是以export指令导出接口,以import引入模块,但是在我们一贯的node模块中,我们采用的是CommonJS...='/favicon.ico'){ console.log('发送响应完毕'); } }); server.listen(1337,"127.0.0.1"); console.log(events.EventEmitter.listenerCount...http.createServer(); var test = function () { server.on('request',function (req,res) { console.log("发送了...='/favicon.ico'){ console.log('发送响应完毕'); } }); server.on('request',test); server.removeListener...,等待事件循环,当主线程再次循环到这个事件的时候,就会直接处理并且返回给上层调用,这个过程就是事件循环(Event Loop)。

95110

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券