[更新: でtop
、プロセスではなくスレッドを表示する shift+H を押した後、Java スレッドが R として表示され、100% の CPU 時間を使用していることを示します。これは、この質問を投稿する前に予想していたことです。]
top
Java プロセスには複数のスレッドがあり、それぞれが異なる状態にある可能性があるため、Linuxコマンドはどのようにして Java プロセスの状態を判断するのでしょうか?
次のコードを実行すると、
public class Test{
public static void main(String[] args){
while (true){
int n = (int)(Math.random() * 1000);
}
}
}
次に、runningtop
は、プロセスの状態が S であり、100% の CPU 時間を使用していることを示しています。
また、実行中のstrace
ショーとショーのみ:
futex(0x7f6ba759c9d0, FUTEX_WAIT, 26060, NULL
ただし、runningjstack
は、メイン スレッドが RUNNABLE であることを示しています。
"main" prio=10 tid=0x00007fd7ec007800 nid=0x669b runnable [0x00007fd7f5754000]
java.lang.Thread.State: RUNNABLE
at Test.main(Test.java:5)
jstack
また、WAITING 状態のスレッドが 2 つしかないことも示しています。
"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)