Bootstrap

进程、线程、纤程、协程

进程

        程序被加载到内存中运行称之为进程,进程是资源分配的基本单位,不同进程之间的地址空间和资源是相互独立的。

线程

        线程是进程内的一个执行单元,进程内的所有线程是共享当前进程的地址空间和资源的,线程是操作系统调度的基本单位。

纤程/协程

        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的消耗。

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;