作者热门文章
- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
Java程序占用的核心数大于线程池的大小是不是有原因?我将线程池大小指定为 4,但我发现我的 java 代码在一段时间后占用了 6 或 7 个内核(即 top 显示 600)。我在这台机器上有 8 个内核。我做错了什么还是java决定在多线程时自动使用其他未使用的内核?如果是,是否有任何方法可以强制在多线程期间使用的内核数?
我使用的代码片段如下所示:
ExecutorService executor = Executors.newFixedThreadPool(4);
for (int i = 0; i < N; i++) {
executor.execute(do something);
}
executor.shutdown();
while (!executor.isTerminated()) {}
最佳答案
JVM 使用多个系统线程,例如 Finalizer 线程。运行 jconsole,连接到您正在运行的应用程序,转到线程选项卡,您将看到所有正在运行的线程。或者将此代码添加到您的应用中
for(Thread t : Thread.getAllStackTraces().keySet()) {
System.out.println(t);
}
关于java - 为什么占用的核心数高于线程池大小?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23798162/
我是一名优秀的程序员,十分优秀!