进程
程序被加载到内存中运行称之为进程,进程是资源分配的基本单位,不同进程之间的地址空间和资源是相互独立的。
线程
线程是进程内的一个执行单元,进程内的所有线程是共享当前进程的地址空间和资源的,线程是操作系统调度的基本单位。
纤程/协程
Oracle JDK中的JVM基于Hotspot实现的,这种实现下JVM中的线程与OS中的线程数量是一一对应的。在JVM中实现多个线程对应OS中的一个线程,这种线程称之为纤程/协程,JAVA中提供了类库Quasar来实现Fiber。
Fiber vsThread
Fiber可以理解为一种轻量化的Thread,实现在JVM中完成对Fiber的调度切换,减少OS内核级别的线程切换的开销,以达到更高效的I/O操作。
纤程与进程对比,纤程对于CPU消耗会高于线程对CPU的消耗,一个OS线程对应的多个纤程,对应OS来说所有的纤程都是处于活跃状态,一个OS线程对应一个用户线程,OS是可以控制线程进入等待状态释放CPU,从而节约CPU的消耗。