[*][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是需要创建的。
注:图示中所用标记不一定很准确,只是想描述一下问题 :) 。
[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是需要创建的。
注:图示中所用标记不一定很准确,只是想描述一下问题 :) 。