为什么占用核心数高于线程池大小?

时间:2014-05-22 05:01:10

标签: java multithreading

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()) {}

1 个答案:

答案 0 :(得分:5)

JVM使用多个系统线程,比如Finalizer线程。运行jconsole,连接到正在运行的应用程序,转到Threads选项卡,您将看到所有正在运行的线程。或者将此代码添加到您的应用

    for(Thread t : Thread.getAllStackTraces().keySet()) {
        System.out.println(t);
    }