詳解nodejs異步I/O和事件循環(huán)
事件驅(qū)動(dòng)模型
現(xiàn)在我們來看看nodejs中的事件驅(qū)動(dòng)和異步I/O是如何實(shí)現(xiàn)的.
nodejs是單線程(single thread)運(yùn)行的,通過一個(gè)事件循環(huán)(event-loop)來循環(huán)取出消息隊(duì)列(event-queue)中的消息進(jìn)行處理,處理過程基本上就是去調(diào)用該消息對(duì)應(yīng)的回調(diào)函數(shù)。消息隊(duì)列就是當(dāng)一個(gè)事件狀態(tài)發(fā)生變化時(shí),就將一個(gè)消息壓入隊(duì)列中。
nodejs的時(shí)間驅(qū)動(dòng)模型一般要注意下面幾個(gè)點(diǎn):
- 因?yàn)槭菃尉€程的,所以當(dāng)順序執(zhí)行js文件中的代碼的時(shí)候,事件循環(huán)是被暫停的。
- 當(dāng)js文件執(zhí)行完以后,事件循環(huán)開始運(yùn)行,并從消息隊(duì)列中取出消息,開始執(zhí)行回調(diào)函數(shù)
- 因?yàn)槭菃尉€程的,所以當(dāng)回調(diào)函數(shù)被執(zhí)行的時(shí)候,事件循環(huán)是被暫停的
- 當(dāng)涉及到I/O操作的時(shí)候,nodejs會(huì)開一個(gè)獨(dú)立的線程來進(jìn)行異步I/O操作,操作結(jié)束以后將消息壓入消息隊(duì)列。
下面我們從一個(gè)簡(jiǎn)單的js文件入手,來看看 nodejs是如何執(zhí)行的。
var fs = require("fs"); var debug = require('debug')('example1'); debug("begin"); fs.readFile('package.json','utf-8',function(err,data){ if(err) debug(err); else debug("get file content"); }); setTimeout(function(){ debug("timeout2"); }); debug('end'); // 運(yùn)行到這里之前,事件循環(huán)是暫停的
- 同步執(zhí)行debug("begin")
- 異步調(diào)用fs.readFile(),此時(shí)會(huì)開一個(gè)新的線程去進(jìn)行異步I/O操作
- 異步調(diào)用setTimeout(),馬上將超時(shí)信息壓入到消息隊(duì)列中
- 同步調(diào)用debug("end")
- 開啟事件循環(huán),彈出消息隊(duì)列中的信息(目前是超時(shí)信息)
- 然后執(zhí)行信息對(duì)應(yīng)的回調(diào)函數(shù)(事件循環(huán)又被暫停)
- 回調(diào)函數(shù)執(zhí)行結(jié)束后,開始事件循環(huán)(目前消息隊(duì)列中沒有任何東西,文件還沒讀完)
- 異步I/O讀取文件完畢,將消息壓入消息隊(duì)列(消息中含有文件內(nèi)容或者是出錯(cuò)信息)
- 事件循環(huán)取得消息,執(zhí)行回調(diào)
- 程序退出。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- nodeJs事件循環(huán)運(yùn)行代碼解析
- 帶你了解NodeJS事件循環(huán)
- Nodejs監(jiān)控事件循環(huán)異常示例詳解
- 我的Node.js學(xué)習(xí)之路(三)--node.js作用、回調(diào)、同步和異步代碼 以及事件循環(huán)
- Node.js事件循環(huán)(Event Loop)和線程池詳解
- 深入理解Node.js 事件循環(huán)和回調(diào)函數(shù)
- 小結(jié)Node.js中非阻塞IO和事件循環(huán)
- 深入淺析Node.js 事件循環(huán)
- 實(shí)例分析JS與Node.js中的事件循環(huán)
- nodejs?快速入門之事件循環(huán)
相關(guān)文章
Node.js內(nèi)置模塊events事件監(jiān)聽發(fā)射詳解
這篇文章主要為大家介紹了Node.js內(nèi)置模塊events事件監(jiān)聽發(fā)射詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02Node.js數(shù)據(jù)流Stream之Readable流和Writable流用法
這篇文章介紹了Node.js數(shù)據(jù)流Stream之Readable流和Writable流的用法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07nodejs進(jìn)階(6)—連接MySQL數(shù)據(jù)庫示例
本篇文章主要介紹了nodejs進(jìn)階(6)—連接MySQL數(shù)據(jù)庫示例,詳細(xì)的介紹了NodeJS操作MySQL數(shù)據(jù)庫,作為應(yīng)用最為廣泛的開源數(shù)據(jù)庫則成為我們的首選,有興趣的可以了解一下。2017-01-01node.js爬蟲框架node-crawler初體驗(yàn)
這篇文章主要介紹了node.js爬蟲框架node-crawler的相關(guān)資料,幫助大家利用node.js進(jìn)行爬蟲,感興趣的朋友可以了解下2020-10-10nodejs實(shí)現(xiàn)郵箱發(fā)送驗(yàn)證碼功能
開發(fā)個(gè)人網(wǎng)站時(shí),注冊(cè)頁面可以使用郵箱驗(yàn)證,于是記錄一下如何用nodejs/express服務(wù)器實(shí)現(xiàn)郵箱發(fā)送驗(yàn)證碼,不僅可以在郵箱注冊(cè)時(shí)使用,還可以拓展用于各種安全驗(yàn)證,本文給大家介紹了使用nodejs實(shí)現(xiàn)郵箱發(fā)送驗(yàn)證碼功能,需要的朋友可以參考下2024-07-07