我在java进程(oracle jdk1.7_072)上运行jstack并找到了这些行
"C2 CompilerThread1" daemon prio=10 tid=0x00007f1a8415d000 nid=0x7d72 waiting on condition [0x0000000000000000]
java.lang.Thread.State: RUNNABLE
"C2 CompilerThread0" daemon prio=10 tid=0x00007f1a8415a000 nid=0x7d71 waiting on condition [0x0000000000000000]
java.lang.Thread.State: RUNNABLE
Run Code Online (Sandbox Code Playgroud)
我知道C2是一个字节码编译器.我有三个问题:
nid
参数是什么意思?第一个nid=0x7d72
看起来类似于java版本,是巧合与否?apa*_*gin 14
-XX:CICompilerCount=N
JVM选项手动覆盖编译器线程的数量.nid
(本机ID)是OS给出的线程的唯一ID.在Linux上,它是gettid()返回的数字.在你的情况下TID = 0x7d72 = 32114.[0x0000000000000000]
这里与之无关waiting on condition
.括号中打印的是与页面大小对齐的最后一个已知Java堆栈帧的堆栈指针.由于编译器线程不是真正的Java线程,因此它没有最后的Java SP,因此打印为零.