在运行时,如何限制java线程的数量

时间:2011-12-09 17:57:16

标签: java multithreading runtime

我在其中一个XSEDE资源上运行基因组装配程序* Trinity,http://trinityrnaseq.sourceforge.net/,如果感兴趣的话。硬件将线程数限制为2500,程序总是希望超过......有一种简单的方法来限制执行的线程数量?我试过了-XX:ParallelGCThreads=16,但这似乎引入了新的错误。

那么,是否存在限制线程总数的运行时命令?

2 个答案:

答案 0 :(得分:2)

使用Executor或ExecutorService。 bragboy的建议是什么,但它内置于Java。

答案 1 :(得分:0)

您可以使用自定义队列作为处理线程数限制的单独进程运行。这样做的好处是您可以选择限制线程,也可以继续添加线程数。你可能会有一个addToQueue(Thread t)类,然后消费者会消耗所有这些线程。队列将知道有多少线程正在运行。如果线程在该范围内,则守护进程将随意触发此队列的consume()方法。在每个线程完成或强制它完成工作后,它会报告回队列。如果您认为应该对正在运行的任务有优先级,则您维护的队列可以是优先级队列。这不仅消除了对JVM的依赖性,而且使您的程序看起来更清晰。