`
gaoyuntao2005
  • 浏览: 303028 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

java并发学之二

阅读更多

在看书的时候看到了一个观察死锁的工具TDA(Thread Dump Analysis) 
看了半天,才知道这玩意儿需要由jvm产生一个Thread Dump 
这个Thread Dump跟之前看到的Heap Dump也不是一回事 
windows下是ctrl+break触发,unix下是ctrl+\或者kill -QUIT pid触发 
默认是输出到System.out,当然,你可以重定向的 

还有一个简单方便快捷的方法:Java VisualVM,并且Java VisualVM中还提供了TDA的插件下载 

太深入的现在还没这水平,在之前的代码调试中用了一下 
之前的代码中有这样一个错误 

Java代码  收藏代码
  1. void waitThread(Thread t) throws InterruptedException  
  2.     {  
  3.         synchronized(this)  
  4.         {         
  5.             freeThread.add((ThreadNode) t);  
  6.             busyThreadsNum.decrementAndGet();  
  7.             synchronized(t)  
  8.             {  
  9.                 t.wait();                     
  10.             }  
  11.         }  
  12.     }  

很明显,问题是锁住了pool的固有锁,然后等待 
这是一个Java VisualVM的一个界面 
 
只要简单地点击“线程 Dump”,就能得到一个线程Dump了,然后用TDA查看一下线程池0-9的状态 

 

可以看到,上锁,然后等待,还有在这问题出现在哪一行,都明晰了 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics