我在其中一个XSEDE资源上运行基因组装配程序* Trinity,http://trinityrnaseq.sourceforge.net/,如果感兴趣的话。硬件将线程数限制为2500,程序总是希望超过......有一种简单的方法来限制执行的线程数量?我试过了-XX:ParallelGCThreads=16
,但这似乎引入了新的错误。
那么,是否存在限制线程总数的运行时命令?
答案 0 :(得分:2)
使用Executor或ExecutorService。 bragboy的建议是什么,但它内置于Java。
答案 1 :(得分:0)
您可以使用自定义队列作为处理线程数限制的单独进程运行。这样做的好处是您可以选择限制线程,也可以继续添加线程数。你可能会有一个addToQueue(Thread t)
类,然后消费者会消耗所有这些线程。队列将知道有多少线程正在运行。如果线程在该范围内,则守护进程将随意触发此队列的consume()
方法。在每个线程完成或强制它完成工作后,它会报告回队列。如果您认为应该对正在运行的任务有优先级,则您维护的队列可以是优先级队列。这不仅消除了对JVM的依赖性,而且使您的程序看起来更清晰。