四、回調函數

Node.js 非同步編程的直接體現就是回調。

非同步編程依託於回調來實現,但不能說使用了回調後程式就非同步化了。

回調函數在完成任務後就會被調用,Node 使用了大量的回調函數,Node 所有 API 都支援回調函數。

例如,我們可以一邊讀取文件,一邊執行其他命令,在文件讀取完成後,我們將文件內容作為回調函數的參數回。

這樣在執行程式碼時就沒有阻塞或等待文件 I/O 操作。這就大大提高了 Node.js 的性能,可以處理大量的並發請求。

回調函數一般作為函數的最後一個參數出現:

function foo1(name, age, callback) { }
function foo2(value, callback1, callback2) { }

一、阻塞程式碼實例

在項目中創建一個input.txt,內容如下:

安靜無言並不是陷入空白,而是有一個更深廣、更澄明的所在。

項目中創建main.js,內容如下:

var fs = require("fs");
var data = fs.readFileSync('input.txt');
console.log(data.toString());
console.log("程式執行結束!");

程式執行結果為:

node main.js
安靜無言並不是陷入空白,而是有一個更深廣、更澄明的所在。
程式執行結束!

以上程式碼先讀取文件內容之後,才能列印「程式執行結束!」。

二、非阻塞程式碼實例

在項目中創建一個input.txt,內容如下:

安靜無言並不是陷入空白,而是有一個更深廣、更澄明的所在。

項目中創建main.js,內容如下:

var fs = require("fs");
fs.readFile('input.txt', function (err, data) {
    if (err) return console.error(err);
    console.log(data.toString());
});
console.log("程式執行結束!");

程式執行結果為:

node main.js
程式執行結束!
安靜無言並不是陷入空白,而是有一個更深廣、更澄明的所在。

以上程式碼可能會先列印「程式執行結束!」,然後讀取文件內容。

三、以上兩種模式的區別

以上兩個實例我們了解了阻塞與非阻塞調用的不同。第一個實例在文件讀取完後才執行程式。 第二個實例我們不

需要等待文件讀取完,這樣就可以在讀取文件時同時執行接下來的程式碼,大大提高了程式的性能。

因此,阻塞是按順序執行的,而非阻塞是不需要按順序的,所以如果需要處理回調函數的參數,我們就需要寫在回

調函數內。

Tags:
Exit mobile version