谈异步线程池的设计

                                                                                  谈异步线程池的设计

          异步线程池的作用就是统一进行线程调度,利用有限的线程处理系统中所有的异步任务。其实一个系统中的异步线程数量跟

CPU的核数是有一定的关系,线程太多,容易浪费资源,而且各个线程之间的CPU调度,也不见得使性能提高,反而会对性能有一定的影响。

但是,线程多,不容易照成死锁。为什么呢?

           很多情况,我们在设计异步线程池的时候,很少去考虑异步任务的依赖的关系,假如一个异步任务在执行过程中会再创建一个异步任务,

并且等待这个异步任务的返回,才最终返回。因此异步任务之间也存在依赖关系。理想的情况下,异步任务之间如果不存在依赖关系,那么

阻塞是作用在调用者线程,这样是不会照成死锁的。因为即使线程数量有限,总会把任务执行完毕。但是如果异步任务如下图的依赖关系,

在有限的线程池规律条件下,是会死锁的。

                                                   

                                                                                   图一:异步任务的依赖关系

    从图一可以看出,假如线程池规模是100,那么如果有100一个并发产生的异步任务A、B、C任务,那么A、B、C产生

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值