java – 拥有比多个线程池更好的单线程池设计
作者:互联网
在Java中拥有多个线程池有什么优缺点?我见过代码,其中有多个线程池用于不同的“类型”任务,我不确定它是更好的设计还是只是开发人员是懒惰的.一个例子是将ScheduledThreadPoolExecutor用于定期执行或超时的任务,并使用另一个ThreadPoolExecutor执行其他任务.
解决方法:
具有单独的专用线程池的目的是使活动不会因线程而变得缺乏,因为其他活动占用了所有线程.如果某个服务有自己的线程池,那么可以确保它拥有一定数量的线程,并且对其他服务的要求不敏感.
使用多个专用线程池,如果一个服务需要太多线程,那么它必须等待线程可用,向系统引入反压使其逐渐降级,并且由于其他部分有自己的线程池,因此它们有机会抓住他们的部分.因此,我们的想法是,随着负载的变化,系统应具有更稳定的特性.在您描述为计划任务设置单独的线程池的情况下,确保无论系统其余部分有多忙,这些任务都会运行.
多个线程池需要调整以确保每个池有足够的线程而不是太多.使用单个线程池,您不需要进行调优,有时可能更好地利用所有线程,但您可能无法预测知道某些重要任务会获得及时完成所需的线程.
标签:threadpoolexecutor,java,multithreading,scheduled-tasks,java-util-concurrent 来源: https://codeday.me/bug/20191001/1837522.html