Node.js 异步编程的直接体现就是回调。
异步编程依托于回调来实现
我们可以一边读取文件,一边执行其他命令,在文件读取完成后,我们将文件内容作为回调函数的参数返回。这样在执行代码时就没有阻塞或等待文件 I/O 操作。这就大大提高了 Node.js 的性能,可以处理大量的并发请求。
i/o操作读写操作
创建一个text文件
阻塞例子:
创建一个执行文件:hello.js
var fs = require("fs");
var data = fs.
readFileSync('hello.txt')
console.log(data.toString())
console.log("程序结束")
执行node hello.js
输出://
$ node hello.js
非阻塞的例子:
var fs = require("fs")
fs.readFile('hello.txt',function(err, data){
if(err){
return console.log.error(error);
}
console.log(data.toString())
})
console.log("程序结束")
输出://
$ node hello.js
以上两个实例我们了解了阻塞与非阻塞调用的不同。第一个实例在文件读取完后才执行完程序。 第二个实例我们不需要等待文件读取完,这样就可以在读取文件时同时执行接下来的代码,大大提高了程序的性能。
因此,
阻塞是按顺序执行的,而非阻塞是不需要按顺序的。