深入解析Node.js中的非阻塞I/O

本篇文章带大家了解一下Node.js中的非阻塞I/O,希望对大家有所帮助!

深入解析Node.js中的非阻塞I/O

如何理解NodeJs的非阻塞I/O

1、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);

结果为一个文件数组

1.png

我们来看一下这个同步操作的执行时间:

    const glob = require("glob");

    let result = null;
    console.time("glob");
    result = glob.sync(__dirname + "/**/*");
    console.timeEnd("glob");

结果:

2.png

一个读取文件的操作,会令进程阻塞33毫秒,这是不能接受的!

接下来,我们使用异步的方式去读取文件

    let result2 = null;
    console.time("glob2");
    glob(__dirname + "/**/*", (err, res) => {
      console.log("glob over");
    });
    console.timeEnd("glob2");

结果:

3.png

执行异步读取文件一共花了4毫秒,并且在执行异步读取文件的过程中我们也能进行其他的操作。

结束语

经过学习,相信大家对非阻塞I/O的理解也更加深刻了,那么,下次见。好好学习,天天向上!

4.png

更多编程相关知识,请访问:编程视频!!

以上就是深入解析Node.js中的非阻塞I/O的详细内容,更多请关注其它相关文章!