我在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=NJVM选项手动覆盖编译器线程的数量.nid(本机ID)是OS给出的线程的唯一ID.在Linux上,它是gettid()返回的数字.在你的情况下TID = 0x7d72 = 32114.[0x0000000000000000]这里与之无关waiting on condition.括号中打印的是与页面大小对齐的最后一个已知Java堆栈帧的堆栈指针.由于编译器线程不是真正的Java线程,因此它没有最后的Java SP,因此打印为零.| 归档时间: |
|
| 查看次数: |
4468 次 |
| 最近记录: |