深入了解Node.js中的非阻塞 I/O-LMLPHP

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

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

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

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

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

排队打饭的例子

深入了解Node.js中的非阻塞 I/O-LMLPHP

阻塞 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);
登录后复制

打印出如下结果

深入了解Node.js中的非阻塞 I/O-LMLPHP

可以看到,需要花费 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 减少了等待时间,在执行过程中也可以执行其他的事情

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

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

09-07 17:53