加入收藏 | 设为首页 | 会员中心 | 我要投稿 应用网_丽江站长网 (http://www.0888zz.com/)- 科技、建站、数据工具、云上网络、机器学习!
当前位置: 首页 > 站长资讯 > 动态 > 正文

常见的 Node.js 面试问题及答案

发布时间:2021-04-12 11:44:35 所属栏目:动态 来源:互联网
导读:时候用 Node.js? Node.js 是异步的、事件驱动的、非阻塞的和单线程的,使得它成为开发下面应用程序的完美候选: 实时应用程序,如聊天和提供实时更新的应用程序 将视频或其他多媒体内容流式传输给大量观众的流式应用程序 其他 I/O 密集型应用程序,如协作平

时候用 Node.js?

Node.js 是异步的、事件驱动的、非阻塞的和单线程的,使得它成为开发下面应用程序的完美候选:

  • 实时应用程序,如聊天和提供实时更新的应用程序
  • 将视频或其他多媒体内容流式传输给大量观众的流式应用程序
  • 其他 I/O 密集型应用程序,如协作平台
  • 遵循微服务架构的网络后端

然而,Node.js 的特性使得它对于其他类型的应用程序来说不是一个理想的选择。执行 CPU 密集型任务的应用程序(如复杂的数学计算)在使用 CPU 时表现不佳,因为 Node.js 是单线程的。

如果你想了解更多这方面的信息,请查看我们的文章 Node.js 架构以及何时在项目中使用。

3. EventEmitter 做了什么?

Node.js 中任何对象发出的事件都是 EventEmitter 类的实例,就像 http 模块。

所有 EventEmitter 类都可以使用 eventEmitter.on() 函数将事件侦听器附加到事件。然后一旦捕捉到这样的事件,就会同步地逐个调用它的侦听器。. 事件循环是什么?

单线程的 Node.js 必须是非阻塞的,以防止线程阻塞在需要很长时间才能完成的任务上,事件循环负责实现这种非阻塞行为,它使用应用程序线程调度挂起的任务。

Node.js 在任务完成时通过回调来处理异步函数返回的响应。与创建任务的事件类似,任务完成后也会发出一个事件。Node.js 将需要处理的事件添加到事件队列。

事件循环对事件队列中的事件进行迭代,并安排何时执行其关联的回调函数。

5. 流是什么?

Stream 流是从源读取或写入数据并将其传输到连续流目标的管道。有四种类型:

  • 可读
  • 可写的
  • 可读写
  • 先写入,再读出来

每个流也是一个 EventEmitter。这意味着流对象可以在流

de.js 能否充分利用多核处理器?

(默认的)Node.js 应用程序总是单线程的,即使在多核处理器上运行,应用程序也能只使用一个处理器。

但是 Node.js 的核心模块之一 Cluster 支持 Node.js 应用程序开启多核,允许我们创建多个工作进程,这些进程可以在多个内核上并行运行,并共享一个端口来侦听事件。

每个进程使用 IPC 与主线程通信,并根据需要将服务器句柄传递给其他进程。主进程可以侦听端口本身并以循环方式将每个新连接传递给子进程,也可以将端口分配给子进程以便子进程侦听请求。

9. 反应堆设计模式是什么?

反应堆设计模式是,Node.js 将回调函数(处理程序)附加到每个 I/O 操作,然后创建请求时将处理程序提交给解复用器。

解复用器收集应用程序中发出的每个 I/O 请求,并将它们作为队列中的事件进行排队。这个队列就是我们所说的事件队列。将事件排队后,解复用器返回应用程序线程的控制。

同时,事件循环遍历事件队列中的每个事件,并调用附加的回调来处理事件响应。

这就是 Node.js 中所使用的反应堆模式。

10. 单线程与多线程网络后端相比有哪些好处?

尽管 Node.js 是单线程的,但是大多数用于后端开发的编程语言都提供多线程来处理应用程序操作。

为什么单线程有利于后端开发?

(编辑:应用网_丽江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读