java – 计算可用于在Threadpool中获得更好性能的最大线程数
|
最近我面临一个采访,面试官问我什么是你可以分配给线程池的最大线程.我回答他这将取决于硬件组合.
他似乎对此并不满意. 任何人都可以告诉我们如何决定我们应该使用哪些最大线程以获得更好的性能.任何指南链接将不胜感激(在核心Java应用程序中) 解决方法任何人都可以告诉我们如何决定我们应该使用哪些最大线程以获得更好的性能 – 它绝对不是最大线程数量.为获得最佳性能,线程数量应等于处理器核心数量(不要忘记使用-XmsYYYYM和-XmxYYYYM,如果没有它们,您可能会遇到处理器未将线程分配给核心的情况). 关于最大线程你的答案是正确的,这取决于硬件和操作系统. cat /proc/sys/kernel/threads-max 编辑. 您可以使用Integer.MAX_VALUE创建线程池 但是你限制了最大线程使用量. 我跑的代码: package com.stackoverflow.test;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class TestMaxAmountOfThreads {
public static void main(String[] args) {
ExecutorService serivce = Executors.newFixedThreadPool(Integer.MAX_VALUE);
for (int i = 0; i < Integer.MAX_VALUE; i++) {
serivce.submit(new Runnable() {
public void run() {
try {
Thread.sleep(Integer.MAX_VALUE);
} catch (InterruptedException e) {
}
}
});
System.out.println(i);
}
}
}
输出:
所以我只能使用31850个线程,没有jvm调优. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
