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)。
更多建議: