Node.js 異步編程的直接體現(xiàn)就是回調。

異步編程依托于回調來實現(xiàn),但不能說使用了回調后程序就異步化了。

回調函數(shù)在完成任務后就會被調用,Node 使用了大量的回調函數(shù),Node 所有 API 都支持回調函數(shù)。

例如,我們可以一邊讀取文件,一邊執(zhí)行其他命令,在文件讀取完成后,我們將文件內(nèi)容作為回調函數(shù)的參數(shù)返回。這樣在執(zhí)行代碼時就沒有阻塞或等待文件 I/O 操作。這就大大提高了 Node.js 的性能,可以處理大量的并發(fā)請求。

回調函數(shù)一般作為函數(shù)的最后一個參數(shù)出現(xiàn):

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

阻塞代碼實例

創(chuàng)建一個文件 input.txt ,內(nèi)容如下:

W3Cschool教程官網(wǎng)地址:hgci.cn

創(chuàng)建 main.js 文件, 代碼如下:

var fs = require("fs");

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

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

以上代碼執(zhí)行結果如下:

$ node main.js
W3Cschool教程官網(wǎng)地址:hgci.cn

程序執(zhí)行結束!

非阻塞代碼實例

創(chuàng)建一個文件 input.txt ,內(nèi)容如下:

W3Cschool教程官網(wǎng)地址:hgci.cn

創(chuàng)建 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("程序執(zhí)行結束!");

以上代碼執(zhí)行結果如下:

$ node main.js
程序執(zhí)行結束!
W3Cschool教程官網(wǎng)地址:hgci.cn

以上兩個實例我們了解了阻塞與非阻塞調用的不同。第一個實例在文件讀取完后才執(zhí)行完程序。 第二個實例我們呢不需要等待文件讀取完,這樣就可以在讀取文件時同時執(zhí)行接下來的代碼,大大提高了程序的性能。

因此,阻塞按是按順序執(zhí)行的,而非阻塞是不需要按順序的,所以如果需要處理回調函數(shù)的參數(shù),我們就需要寫在回調函數(shù)內(nèi)。