小编Oli*_*ver的帖子

Java线程转储:没有"等待锁定......"的BLOCKED线程

我很难理解我从jstack获得的在Tomcat 6上运行的Spring MVC Web应用程序的线程转储(java 1.6.0_22,Linux).

我看到阻塞线程(导致其他线程等待)自己被阻塞,但是线程转储没有告诉我为什么或者他们正在等待哪个监视器.

例:

"TP-Processor75" daemon prio=10 tid=0x00007f3e88448800 nid=0x56f5 waiting for monitor entry [0x00000000472bc000]
    java.lang.Thread.State: BLOCKED (on object monitor)
        at java.lang.Class.initAnnotationsIfNecessary(Class.java:3067)
        - locked <0x00007f3e9a0b3830> (a java.lang.Class for org.catapultframework.resource.ResourceObject)
        at java.lang.Class.getAnnotation(Class.java:3029)
        ...
Run Code Online (Sandbox Code Playgroud)

即我错过了堆栈跟踪中的"等待锁定..."行.显然线程锁定了一个Class对象,但是我不明白为什么线程本身被阻塞了.

线程转储不包含任何死锁提示.

如何识别锁定监视器?

谢谢,奥利弗

java jstack thread-dump

20
推荐指数
2
解决办法
5万
查看次数

标签 统计

java ×1

jstack ×1

thread-dump ×1