gpt4 book ai didi

java - Linux top命令如何确定Java进程的状态?

转载 作者:IT王子 更新时间:2023-10-29 00:36:12 25 4
gpt4 key购买 nike

[更新:在 top 中,在我按下 shift+H 后,显示线程而不是进程,然后它显示 Java 线程为 R 并使用 100% CPU 时间,这是我所期望的在发布这个问题之前。]

既然Java进程有多个线程,每个线程可能处于不同的状态,那么Linux的top命令是如何判断Java进程状态的呢?

如果我运行下面的代码,

public class Test{
public static void main(String[] args){
while (true){
int n = (int)(Math.random() * 1000);
}
}
}

然后,运行 top 显示进程状态为 S,并且它正在使用 100% 的 CPU 时间。

此外,运行 strace 显示且仅显示:

futex(0x7f6ba759c9d0, FUTEX_WAIT, 26060, NULL

但是,运行jstack显示主线程是RUNNABLE的:

"main" prio=10 tid=0x00007fd7ec007800 nid=0x669b runnable [0x00007fd7f5754000]
java.lang.Thread.State: RUNNABLE
at Test.main(Test.java:5)

jstack 也显示,只有两个线程处于 WAITING 状态:

"Finalizer" daemon prio=10 tid=0x00007fd7ec080000 nid=0x66a6 in Object.wait() [0x00007fd7f0252000]
java.lang.Thread.State: WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
- waiting on <0x00000007ad001310> (a java.lang.ref.ReferenceQueue$Lock)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:133)
- locked <0x00000007ad001310> (a java.lang.ref.ReferenceQueue$Lock)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:149)
at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:177)

"Reference Handler" daemon prio=10 tid=0x00007fd7ec07e000 nid=0x66a5 in Object.wait() [0x00007fd7f0353000]
java.lang.Thread.State: WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
- waiting on <0x00000007ad0011e8> (a java.lang.ref.Reference$Lock)
at java.lang.Object.wait(Object.java:502)
at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:133)
- locked <0x00000007ad0011e8> (a java.lang.ref.Reference$Lock)

最佳答案

JVM 有许多 线程在运行以执行“内务处理”,如垃圾收集等。它们大部分时间都处于 sleep 状态。

关于java - Linux top命令如何确定Java进程的状态?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14095877/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com