Node.js 回調函數 阻塞與非阻塞

Node.js異步變成的直接體現就是回調。
異步編程依託於回調來實現,但不能說使用了回調後程序就異步化了。
回調函數在完成任務後就會被調用,Node使用了大量的回調函數,Node全部的APi都支持回調函數。
好比,咱們i 遍讀文件,一邊執行其餘命令,在文件讀取完成後,咱們將文件內容做爲回調函數都參數返回。
這樣在執行代碼時就沒有阻塞或等待文件I/O操做。這就大大提升了Node都性能,能夠處理大量的併發請求。前端

接下來寫一個阻塞代碼實例
建立一個文件input.txt,內容以下
學習前端知識,記錄筆記 ,來segmentfault。編程

建立main.js 文件,代碼以下:segmentfault

const fs = require("fs") //fs模塊用於對系統文件及目錄進行讀寫操做。

const data = fs.readFileSync('input.txt');

console.log(data.toString());
console.log("執行程序結束")

非阻塞代碼實例併發

const fs = require("fs") //fs模塊用於對系統文件及目錄進行讀寫操做。

fs.readFile('input.txt',(err, data) => {
    if(err) {
        console.log(err)
    }else{
        console.log(data.toString())
    }
})
console.log("程序執行結束!")

以上兩個實例寫出了阻塞與非阻塞的不一樣。第一個實例在文件讀取完後才執行完程序。
第二個實例咱們不須要等待文件讀取完,這樣就能夠在讀取文件時同時執行接下來的代碼,大大提升了程序的性能。異步

所以,阻塞是按順序執行的,而非阻塞是不須要按順序的,因此若是須要處理回調函數的參數,咱們就須要寫在回調函數內。異步編程

相關文章
相關標籤/搜索