美文网首页
深入了解Node.js中的非阻塞 I/O(转载)

深入了解Node.js中的非阻塞 I/O(转载)

作者: 浅浅而谈 | 来源:发表于2021-07-05 10:07 被阅读0次
    image

    说到 Node.js,大家大概率听过一堆让人头晕的专有名词

    关于异步,主要是事件循环非阻塞 I/O,正式因为这两点 Node.js 才能称作高性能。

    因此搞清楚 Node.js 的异步机制和使用方法是很重要的

    Node.js 的非阻塞 I/O 是什么

    • I/O 即 Input/Output,一个系统的而输入和输出
    • 阻塞 I/O 和非阻塞 I/O 的区别就在于系统接收输入再到输出的时间,能不能接收其他输入

    排队打饭的例子

    1.gif

    阻塞 I/O 和非阻塞 I/O 的区别就在于系统接收输入再到输出的时间,能不能接收其他输入

    • 对于顾客/点菜人员来说

      • 排队打饭是阻塞 I/O(后面的顾客必须等待前面顾客的收到后自己才能收到)
      • 餐厅点菜是非阻塞 I/O(因为餐厅有很多个服务员,别人点菜的同时,自己也可以点菜)
    • 把食堂阿姨、服务员比作软件系统

      • 食堂阿姨只能一份份地打饭 -> 阻塞 I/O
      • 服务生点完菜后还可以服务其他客人 -> 非阻塞 I/O
    • 输入 = 点菜

    • 输出 = 端菜

    【推荐学习:《nodejs 教程》】

    提问等待解决的例子

    例如: 一个开发者在论坛上提出了一个问题: "这个 Node.js 问题怎么解决? 在线等,急" .

    阻塞 I/O 的情况就是 -> 他一直等待其他人回答,当其他人回答后,他再去做其他的事 。

    非阻塞 I/O 的情况就是 -> 他去做其他的事 ,过一段时间后再回来看答案

    做家务的例子

    小芳做家务,需要做如下事情:

    • 用洗衣机洗衣服(20 分钟))
    • 扫地(10 分钟)
    • 整理书桌(10 分钟)
    • 晾衣服(10 分钟)

    请设计一个巧妙合理的顺序,使小芳花最少的时间完成这些事

    • A:20 分钟
    • B:25 分钟
    • C:30 分钟--因为洗衣机洗衣服时,小芳可以做其他的事 ✅
    • D:35 分钟

    理解非阻塞 I/O

    注意点:

    • 确定 系统,输入,输出,分别是什么
    • 在 I/O 过程中, 能不能进行其他 I/O

    从代码理解阻塞 I/O

    const glob = require("glob");
    
    var result = null;
    console.time("glob");
    // 获取目下的文件和文件名
    result = glob.sync(__dirname + "/**/*");
    console.timeEnd("glob");
    console.log(result);
    

    打印出如下结果

    2.gif

    可以看到,需要花费 30 毫秒的等待时间才能拿到结果

    从上面的代码可以得出,

    阻塞 I/O 有一个等待时间,在执行过程中不可以执行其他的事情

    从代码理解非阻塞 I/O

    const glob = require("glob");
    
    var result = null;
    console.time("glob");
    // 获取目下的文件和文件名
    glob(__dirname + "/**/*", function (err, res) {
      result = res;
      console.log("got result");
    });
    console.timeEnd("glob");
    
    console.log(1 + 1);
    

    打印出如下结果

    glob: 3.198ms
    2
    got result
    

    从上面的代码可以得出,非阻塞 I/O 减少了等待时间,在执行过程中也可以执行其他的事情

    本文转载自:https://www.php.cn/js-tutorial-479104.html

    更多编程相关知识,请访问:编程入门!!

    相关文章

      网友评论

          本文标题:深入了解Node.js中的非阻塞 I/O(转载)

          本文链接:https://www.haomeiwen.com/subject/nppbultx.html