詳解nodejs異步I/O和事件循環(huán)

事件驅動模型

創(chuàng)新互聯(lián)專注于企業(yè)網絡營銷推廣、網站重做改版、美蘭網站定制設計、自適應品牌網站建設、H5建站、商城網站定制開發(fā)、集團公司官網建設、成都外貿網站制作、高端網站制作、響應式網頁設計等建站業(yè)務,價格優(yōu)惠性價比高,為美蘭等各大城市提供網站開發(fā)制作服務。

現在我們來看看nodejs中的事件驅動和異步I/O是如何實現的.

nodejs是單線程(single thread)運行的,通過一個事件循環(huán)(event-loop)來循環(huán)取出消息隊列(event-queue)中的消息進行處理,處理過程基本上就是去調用該消息對應的回調函數。消息隊列就是當一個事件狀態(tài)發(fā)生變化時,就將一個消息壓入隊列中。

nodejs的時間驅動模型一般要注意下面幾個點:

  1. 因為是單線程的,所以當順序執(zhí)行js文件中的代碼的時候,事件循環(huán)是被暫停的。
  2. 當js文件執(zhí)行完以后,事件循環(huán)開始運行,并從消息隊列中取出消息,開始執(zhí)行回調函數
  3. 因為是單線程的,所以當回調函數被執(zhí)行的時候,事件循環(huán)是被暫停的
  4. 當涉及到I/O操作的時候,nodejs會開一個獨立的線程來進行異步I/O操作,操作結束以后將消息壓入消息隊列。

下面我們從一個簡單的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'); // 運行到這里之前,事件循環(huán)是暫停的
  1. 同步執(zhí)行debug("begin")
  2. 異步調用fs.readFile(),此時會開一個新的線程去進行異步I/O操作
  3. 異步調用setTimeout(),馬上將超時信息壓入到消息隊列中
  4. 同步調用debug("end")
  5. 開啟事件循環(huán),彈出消息隊列中的信息(目前是超時信息)
  6. 然后執(zhí)行信息對應的回調函數(事件循環(huán)又被暫停)
  7. 回調函數執(zhí)行結束后,開始事件循環(huán)(目前消息隊列中沒有任何東西,文件還沒讀完)
  8. 異步I/O讀取文件完畢,將消息壓入消息隊列(消息中含有文件內容或者是出錯信息)
  9. 事件循環(huán)取得消息,執(zhí)行回調
  10. 程序退出。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

網頁名稱:詳解nodejs異步I/O和事件循環(huán)
標題路徑:http://muchs.cn/article48/isphep.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供Google、網站導航服務器托管、靜態(tài)網站、小程序開發(fā)網站營銷

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

網站建設網站維護公司