node基础 --概念

非阻塞IO:

node.js使用了事件轮询

  • setTimeout是非阻塞的;
  • 对于像http,net等原生模块中IO部分也采用了事件轮询,其本质是:
    • 当node接受到浏览器的http请求时,底层的TCP连接会分配一个文件描述符;然后,当客户端向服务器发送数据,node会收到该文件描述符上的通知,然后促发回调函数。

单线程:

当V8首次调用一个函数时,会创建一个调用堆栈;如果这个函数再调用其他函数,V8会把它添加到调用堆栈中;在单线程的环境下,当调用堆栈展开时,node就无法处理其他请求。

所以实际上node不是多并发的(最大量为1),但V8执行js速度很快,加上非阻塞io,确保一般操作不会挂起;

事件循环:

  • 所有的异步 I/O 操作在完成时都会发送一个事件到事件队列。在开发者看来,事件由 EventEmitter 对象提供。
  • Node.js 的事件循环机制:Node.js 程序由事件循环开始,到事件循环结束,所有的逻辑都是事件的回调函数,所以 Node.js 始终在事件循环中,程序入口就是事件循环第一个事件的回调函数。事件循环会检查事件队列中有没有未处理的事件,直到程序结束。

原文地址:https://www.cnblogs.com/jinkspeng/p/4054916.html