提到node,咱们就能够马上想到单线程、异步IO、事件驱动等字眼。首先要明确的是node真的是单线程的吗,若是是单线程的,那么异步IO,以及定时事件(setTimeout、setInterval等)又是在哪里被执行的。node
其实,按照严格来讲,node并非单线程的。node中存在着多种线程,包括:ajax
...多线程
咱们平时所说的单线程是指node中只有一个js引擎在主线程上运行。其余异步IO和事件驱动相关的线程经过libuv来实现内部的线程池和线程调度。libv中存在了一个Event Loop,经过Event Loop来切换实现相似于多线程的效果。简单的来说Event Loop就是维持一个执行栈和一个事件队列,当前执行栈中的若是发现异步IO以及定时器等函数,就会把这些异步回调函数放入到事件队列中。当前执行栈执行完成后,从事件队列中,按照必定的顺序执行事件队列中的异步回调函数。异步
上图中从执行栈,到事件队列,最后事件队列中按照必定的顺序执行回调函数,整个过程就是一个简化版的Event Loop。此外回调函数执行时,一样会生成一个执行栈,在回调函数里面还有可能嵌套异步的函数,也就是说执行栈存在着嵌套。函数
也就是说node中的单线程是指js引擎只在惟一的主线程上运行,其余的异步操做,也是有独立的线程去执行,经过libv的Event Loop实现了相似于多线程的上下文切换以及线程池调度。线程是最小的进程,所以node也是单进程的。这样就解释了为何node是单线程和单进程的。oop