首頁 > web前端 > js教程 > 深入解析Node.js中的非阻塞I/O

深入解析Node.js中的非阻塞I/O

青灯夜游
發布: 2021-11-03 19:19:10
轉載
1844 人瀏覽過

這篇文章帶大家了解一下Node.js中的非阻塞I/O,希望對大家有幫助!

深入解析Node.js中的非阻塞I/O

如何理解NodeJs的非阻塞I/O

1、I/O:即 Input /output  指一個系統的輸入和輸出

2 、非阻塞和阻塞的主要區別在:在接收輸入到輸出結果之間的過程中,能否繼續接收其他的輸入【推薦學習:《nodejs 教學》】

#範例:

比說:出去吃飯

出去吃飯通常有兩種方式:
1 去食堂吃:排隊打飯

  • [排隊] - [等前面的人吃飯] - [自己吃飯] - [吃]

2 去餐廳吃

  • [坐下] - [ 點菜] - [ 等待] - [ 吃飯]

針對這兩種吃飯方式而言:

  • 1 食堂吃:對於吃飯人員而言,必須等前面一個人打完了,才會打下一個人的飯,這個過程就是阻塞模式

  • 2 餐廳吃:去餐廳吃飯,服務員在給你點完餐後,回繼續處理下一個人的點餐需求,等到你的飯好了,再將飯給你送過來,對於服務員而言,這個過程就是非阻塞的過程

#理解非阻塞I/O的要點

  • #1 確定一個進行I/O操作的系統,比如說:在上面的打飯例子裡面,進行I/O的系統就是服務人員。

  • 2 在系統進行I/O操作的過程中能否再進行其他的I/O

#程式碼示範

範例程式碼裡面我們引進了一個函式庫glob,這個函式庫主要是用來找出符合條件的檔案。 詳情請看https://www.npmjs.com/package/glob

首先,我們先使用glob提供的同步的方法來讀取檔案

    const glob = require("glob");
    let result = null;
    result = glob.sync(__dirname + "/**/*");
    console.log(result);
登入後複製

結果為一個檔案陣列

深入解析Node.js中的非阻塞I/O

我們來看看這個同步運算的執行時間:

    const glob = require("glob");

    let result = null;
    console.time("glob");
    result = glob.sync(__dirname + "/**/*");
    console.timeEnd("glob");
登入後複製

結果:

深入解析Node.js中的非阻塞I/O

一個讀取檔案的操作,會讓進程阻塞33毫秒,這是不能接受的!

接下來,我們使用非同步的方式去讀取檔案

    let result2 = null;
    console.time("glob2");
    glob(__dirname + "/**/*", (err, res) => {
      console.log("glob over");
    });
    console.timeEnd("glob2");
登入後複製

結果:

深入解析Node.js中的非阻塞I/O

執行異步讀取檔案總共花了4毫秒,在執行非同步讀取檔案的過程中我們也能進行其他的操作。

結束語

經過學習,相信大家對非阻塞I/O的理解也更加深刻了,那麼,下次見。好好學習,天天向上!

深入解析Node.js中的非阻塞I/O

更多程式相關知識,請造訪:程式設計影片! !

以上是深入解析Node.js中的非阻塞I/O的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:juejin.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板