Node.js 異步編程的直接體現就是回調。編程
異步編程依託於回調來實現,但不能說使用了回調後程序就異步化了。併發
回調函數在完成任務後就會被調用,Node 使用了大量的回調函數,Node 全部 API 都支持回調函數。異步
例如,咱們能夠一邊讀取文件,一邊執行其餘命令,在文件讀取完成後,咱們將文件內容做爲回調函數的參數返回。這樣在執行代碼時就沒有阻塞或等待文件 I/O 操做。這就大大提升了 Node.js 的性能,能夠處理大量的併發請求。異步編程
阻塞代碼實例函數
一、建立一個文件 input.txt ,內容以下:性能
i have a dreamui
二、建立 main.js 文件, 代碼以下:spa
var fs = require("fs"); var data = fs.readFileSync('input.txt'); //注:同步版的 fs.readFile()
console.log(data.toString()); console.log("程序執行結束!");
以上代碼執行結果以下:code
非阻塞代碼實例blog
一、建立一個文件 input.txt ,內容以下:
i have a dream
二、建立 main.js 文件, 代碼以下:
var fs = require("fs"); fs.readFile('input.txt', function (err, data) { //注:異步版的 fs.readFile() if (err) return console.error(err); console.log(data.toString()); }); console.log("程序執行結束!");
以上代碼執行結果以下:
總結:
以上兩個實例咱們瞭解了阻塞與非阻塞調用的不一樣。
第一個實例在文件讀取完後才執行完程序。
第二個實例咱們呢不須要等待文件讀取完,這樣就能夠在讀取文件時同時執行接下來的代碼,大大提升了程序的性能。
所以,阻塞按是按順序執行的,而非阻塞是不須要按順序的,因此若是須要處理回調函數的參數,咱們就須要寫在回調函數內。