Java程序占用的内核数量是否高于线程池的大小?我正在指定线程池大小为4,但我看到我的java代码在一段时间后占据了6或7个核心(即顶部显示600)。我在这台机器上有8个核心。我是做错了什么,还是java决定在执行多线程时自动使用其他未使用的核心?如果是,有没有办法强制在多线程过程中使用内核的数量?
我使用的代码如下所示:
ExecutorService executor = Executors.newFixedThreadPool(4);
for (int i = 0; i < N; i++) {
executor.execute(do something);
}
executor.shutdown();
while (!executor.isTerminated()) {}发布于 2014-05-22 05:18:58
JVM使用了几个系统线程,比如终结器线程。运行j控制台,连接到您正在运行的应用程序,转到threads选项卡,您将看到所有正在运行的线程。或者将这些代码添加到应用程序中。
for(Thread t : Thread.getAllStackTraces().keySet()) {
System.out.println(t);
}https://stackoverflow.com/questions/23798162
复制相似问题