我在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
我知道C2是一个字节码编译器.我有三个问题:
>为什么有2个编译器线程?可以或多或少吗?如果是的话,何时?编译是否并行运行?
> nid参数是什么意思?第一个nid = 0x7d72看起来类似于java版本,是巧合还是不巧合?
>为什么条件地址是绝对零?
解决方法:
>根据JVM人机工程学自动确定编译器线程的数量.它可能会根据可用CPU的数量而有所不同.确切的公式可以找到here.可以使用-XX:CICompilerCount = N JVM选项手动覆盖编译器线程的数量.
> nid(Native ID)是OS给出的线程的唯一ID.在Linux上,它是gettid()返回的数字.在您的情况下,TID = 0x7d72 = 32114.
> [0x0000000000000000]这里与等待条件无关.括号中打印的是与页面大小对齐的最后一个已知Java堆栈帧的堆栈指针.由于编译器线程不是真正的Java线程,因此它没有最后的Java SP,因此打印为零.
标签:java,jvm,jit
来源: https://codeday.me/bug/20190713/1453523.html