Node.js 回调函数(阻塞与非阻塞)
程序员文章站
2022-03-26 12:13:39
Node.js 异步编程的直接体现就是回调。 回调函数在完成任务后就会被调用,Node 使用了大量的回调函数,Node 所有 API 都支持回调函数。 例如,我们可以一边读取文件,一边执行其他命令,在文件读取完成后,我们将文件内容作为回调函数的参数返回。 这样在执行代码时就没有阻塞或等待文件 I/O ......
node.js 异步编程的直接体现就是回调。
回调函数在完成任务后就会被调用,node 使用了大量的回调函数,node 所有 api 都支持回调函数。
例如,我们可以一边读取文件,一边执行其他命令,在文件读取完成后,我们将文件内容作为回调函数的参数返回。
这样在执行代码时就没有阻塞或等待文件 i/o 操作。这就大大提高了 node.js 的性能,可以处理大量的并发请求。
回调函数一般作为函数的最后一个参数出现:
function foo1(name, age, callback) { } function foo2(value, callback1, callback2) { }
阻塞代码实例:
创建input.txt
这是cyy,正在学习node.js
创建main.js
var fs=require("fs"); var data=fs.readfilesync("input.txt"); console.log(data.tostring()); console.log("文件读取完毕~");
node main.js
fs模块用于对系统文件及目录进行读写操作。
使用require('fs')载入fs模块,模块中所有方法都有同步和异步两种形式。
这里演示的是同步效果
非阻塞代码
修改main.js
var fs=require("fs"); fs.readfile("input.txt",function(err,data){ if(err){ return console.error(err); }else{ console.log(data.tostring()); } }); console.log("文件读取完毕~");
以上展示了阻塞与非阻塞调用的不同。
第一个实例在文件读取完后才执行程序。
第二个实例我们不需要等待文件读取完,这样就可以在读取文件时同时执行接下来的代码,大大提高了程序的性能。
因此,阻塞是按顺序执行的,而非阻塞是不需要按顺序的,所以如果需要处理回调函数的参数,就需要写在回调函数内。
上一篇: 修复使用sub和sup时的行间距问题
下一篇: 块级元素与行内元素的区别