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的插件下载

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

void waitThread(Thread t) throws InterruptedException
{
synchronized(this)
{
freeThread.add((ThreadNode) t);
busyThreadsNum.decrementAndGet();
synchronized(t)
{
t.wait();
}
}
}


很明显,问题是锁住了pool的固有锁,然后等待
这是一个Java VisualVM的一个界面
[img]http://dl.iteye.com/upload/attachment/445160/443ee935-8ce3-3dba-ba6d-715fef3cf340.png[/img]
只要简单地点击“线程 Dump”,就能得到一个线程Dump了,然后用TDA查看一下线程池0-9的状态

[img]http://dl.iteye.com/upload/attachment/445165/b2e3929e-c6c1-38f9-9db9-7284d6996447.png[/img]

可以看到,上锁,然后等待,还有在这问题出现在哪一行,都明晰了
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值