进程、线程、纤程、协程

进程

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

线程

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

纤程/协程

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值