首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在运行时,如何限制java线程的数量?

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

Stack Overflow用户
提问于 2011-12-10 01:57:16
回答 2查看 452关注 0票数 9

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

那么,有没有一个运行时命令来限制线程总数呢?

EN

回答 2

Stack Overflow用户

发布于 2011-12-10 04:30:53

使用Executor或ExecutorService。按照吹牛男孩的建议做,但它是内置在Java中的。

票数 2
EN

Stack Overflow用户

发布于 2011-12-10 02:24:43

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8449714

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档