Node 是一个让 JavaScript 运行在服务端的开发平台, Node 可以在不新增额外线程的情况下, 依然可以对任务进行并发处理 -- Node.JS 是单线程的.
线程
线程是操作系统能够进行运算调度的最小单位, 首先我们要清楚线程是隶属于进程的, 被包含于进程之中. 一个线程只能隶属于一个进程, 但是一个进程是可以拥有多个线程的.
单线程就是一个进程只开一个线程
Node.JS 中的进程
process 模块
Node.JS 中的进程 Process 是一个全局对象, 无需 require 直接使用, 给我们提供了当前进程中的相关信息.
node 中进程可以使用 child_process 模块创建.
关系:
一个线程只能属于一个进程, 而一个进程可以有多个线程, 但至少有一个线程 (通常说的主线程).
源分配给进程, 同一进程的所有线程共享该进程的所有资源. 用户进程主要段 segment:stack(向低地址),heap,.rodata,data/bss,.text. 一个进程, 上面的 5 部分是主要的, 必须的. 线程只拥有 stack(线程栈, 线程栈是单个线程所独享的, 2M), 保存自己的函数调用过程, 比如 heap,.rodata,data/bss,text 段都是共享的.
程在执行过程中, 需要协作同步. 不同进程的线程间要利用消息通信的办法实现同步.
处理机分给线程, 即真正在处理机上运行的是线程.
线程是指进程内的一个执行单元, 也是进程内的可调度实体.
node 进程与线程的区别:
调度: 线程作为调度和分配的基本单位, 进程作为拥有资源的基本单位.
拥有资源: 进程是拥有资源的一个独立单位, 线程不拥有系统资源, 但可以访问隶属于进程的资源.
来源: http://www.css88.com/qa/node-js/12168.html