本篇文章带大家了解一下Node.js中的非阻塞I/O,希望对大家有所帮助!
如何理解NodeJs的非阻塞I/O1、I/O:即 Input/output 指一个系统的输入和输出
2 、非阻塞和阻塞的主要区别在:在接收输入到输出结果之间的过程中,能否继续接收其他的输入。【推荐学习:《nodejs 教程》】
例子:
比如说:出去吃饭
出去吃饭通常有两种方式:
1 去食堂吃:排队打饭
[排队] - [等前面的人打饭 ] - [自己打饭 ] - [吃饭]
2 去餐厅吃
[坐下 ] - [ 点菜] - [ 等待] - [ 吃饭]
针对这两种吃饭方式而言:
1 食堂吃:对于打饭人员而言,必须等前面一个人打完了,才会打下一个人的饭,这个过程就是阻塞模式
2 餐厅吃:去餐厅吃饭,服务员在给你点完餐之后,回继续处理下一个人的点餐需求,等到你的饭好了,再将饭给你送过来,对于服务员而言,这个过程就是非阻塞的过程
理解非阻塞I/O的要点
1 确定一个进行I/O操作的系统,比如说:在上面的打饭例子里面,进行I/O的系统就是服务人员。
2 在系统进行I/O操作的过程中能否再进行其他的I/O
代码演示
示例代码里面我们引入了一个库 glob,这个库主要是用来查找匹配条件的文件。 详情请看 https://www.npmjs.com/package/glob
首先,我们先使用glob提供的同步的方法来读取文件
const glob = require("glob"); let result = null; result = glob.sync(__dirname + "/**/*"); console.log(result);
结果为一个文件数组:
我们来看一下这个同步操作的执行时间:
const glob = require("glob"); let result = null; console.time("glob"); result = glob.sync(__dirname + "/**/*"); console.timeEnd("glob");
结果:
一个读取文件的操作,会令进程阻塞33毫秒,这是不能接受的!
接下来,我们使用异步的方式去读取文件
let result2 = null; console.time("glob2"); glob(__dirname + "/**/*", (err, res) => { console.log("glob over"); }); console.timeEnd("glob2");
结果:
执行异步读取文件一共花了4毫秒,并且在执行异步读取文件的过程中我们也能进行其他的操作。
结束语经过学习,相信大家对非阻塞I/O的理解也更加深刻了,那么,下次见。好好学习,天天向上!
更多编程相关知识,请访问:编程视频!!