深入了解Node.js中的非阻塞 I/O
说到 Node.js,大家大概率听过一堆让人头晕的专有名词
关于异步,主要是事件循环和**非阻塞 I/O,**正式因为这两点 Node.js 才能称作高性能。
因此搞清楚 Node.js 的异步机制和使用方法是很重要的
Node.js 的非阻塞 I/O 是什么
- I/O 即 Input/Output,一个系统的而输入和输出
- 阻塞 I/O 和非阻塞 I/O 的区别就在于系统接收输入再到输出的时间,能不能接收其他输入
排队打饭的例子
阻塞 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);
打印出如下结果
可以看到,需要花费 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的详细内容,更多请关注其它相关文章!