NodeJs 理解非阻塞I/O

1,084 阅读2分钟

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

1 I/O:即 Input/output 指一个系统的输入和输出
2 非阻塞和阻塞的主要区别在:在接收输入到输出结果之间的过程中,能否继续接收其他的输入

例子

1.jpeg

比如说:出去吃饭
出去吃饭通常有两种方式:
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);

结果为一个文件数组image.png

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

    const glob = require("glob");

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

结果:

image.png

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

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

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

结果:

image.png

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

结束语

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

4.jpg