线程池和车间模式

[*][size=large]问题描述:[/size]
[img]http://dl.iteye.com/upload/picture/pic/76576/6e0cee78-4512-3e59-9b88-bf1092648c20.jpg[/img]
一个对象,需要多个步骤处理,之所以要分开处理,是因为:
1、这样的对象很多
2、每个步骤耗时不一样,有的步骤可能是IO操作


[*][size=x-large]解决方案[/size]
[*][size=large]方案一:线程池处理[/size]
[img]http://dl.iteye.com/upload/picture/pic/76574/743724e5-1877-3fba-8664-3fbfed7e46f6.jpg[/img]
使用JDK自带的ExecutorService pool = Executors.newFixedThreadPool(10)方式很容易实现线程池的管理


[*][size=large]方案二:车间模式[/size]
[img]http://dl.iteye.com/upload/picture/pic/76572/2967430d-0532-3423-91b7-521c84d0041d.jpg[/img]
在车间中,车间只负责对对象进行处理,车间甚至不需要知道怎么获取需要处理的对象,也不需要知道处理完成对象之后交到何处,因为这个可以由别的资源来处理这个对象的传输、调度问题。


[*]区别:两种方式的区别在于,“车间”线程在程序运行期间,是不需要销毁的,车间线程在有需要处理的对象的时候,依照规则处理对象,在没有需处理的对象的时候,“车间”线程空闲;而线程池处理方式中,虽然线程池里的线程也是不需要销毁的,但是需要被执行的Task是需要创建的。

注:图示中所用标记不一定很准确,只是想描述一下问题 :) 。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值