如何理解NodeJs的非阻塞I/O
1 I/O:即 Input/output 指一个系统的输入和输出
2 非阻塞和阻塞的主要区别在:在接收输入到输出结果之间的过程中,能否继续接收其他的输入。
例子
比如说:出去吃饭
出去吃饭通常有两种方式:
1 去食堂吃:排队打饭
- [排队] - [等前面的人打饭 ] - [自己打饭 ] - [吃饭]
2 去餐厅吃
- [坐下 ] - [ 点菜] - [ 等待] - [ 吃饭]
针对这两种吃饭方式而言:
1 食堂吃:对于打饭人员而言,必须等前面一个人打完了,才会打下一个人的饭,这个过程就是阻塞模式
2 餐厅吃:去餐厅吃饭,服务员在给你点完餐之后,回继续处理下一个人的点餐需求,等到你的饭好了,再将饭给你送过来,对于服务员而言,这个过程就是非阻塞的过程
理解非阻塞I/O的要点
1 确定一个进行I/O操作的系统,比如说:在上面的打饭例子里面,进行I/O的系统就是服务人员。
2 在系统进行I/O操作的过程中能否再进行其他的I/O
代码演示
示例代码里面我们引入了一个库 glob,这个库主要是用来查找匹配条件的文件。 详情请看 www.npmjs.com/package/glo…
首先,我们先使用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的理解也更加深刻了,那么,下次见。好好学习,天天向上!
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
发表评论
还没有评论,快来抢沙发吧!