那我们怎么确定一定是死锁呢?有两种方法。

  1>使用JDK给我们的的工具JConsole,可以通过打开cmd然后输入jconsole打开。

    1)连接到需要查看的进程。

2)打开线程选项卡,然后点击左下角的“检测死锁”

    3)jconsole就会给我们检测出该线程中造成死锁的线程,点击选中即可查看详情:

     从上图中我们可以看出:

      ①在线程Thread-1中,从状态可以看出,它想申请Paper这个资源,但是这个资源已经被Thread-0拥有了,所以就堵塞了。

      ②在线程Thread-0中,从状态可以看出,它想申请Pen这个资源,但是这个资源已经被Thread-1拥有了,所以就堵塞了。

    Thread-1一直等待paper资源,而Thread--一直等待pen资源,于是这两个线程就这么僵持了下去,造成了死锁。

  2>直接使用JVM自带的命令

    1)首先通过 jps 命令查看需要查看的Java进程的vmid,如图,我们要查看的进程TestDeadLock的vmid号是7412;

    

    2)然后利用 jstack 查看该进程中的堆栈情况,在cmd中输入 jstack -l 7412 ,移动到输出的信息的最下面即可得到:

    

    至此,相信大家都会看了吧,具体就不说啦,根据输出,找到问题所在的代码,开始调试解决即可啦。

最新文章

  1. iOS之数字的格式化
  2. Java 自动装箱与拆箱(Autoboxing and unboxing)
  3. iOS:界面适配(三)--iPhone不同机型适配 6/6plus 前
  4. Linux objcopy命令
  5. Swig 使用指南
  6. extjs grid 单元格 多选
  7. Sublime安装插件的方法
  8. Appium Python Driver Api
  9. USB自定义HID设备实现-LPC1768
  10. matlab R2016a 中添加新的工具箱的方法
  11. 流处理与消息队列------《Designing Data-Intensive Applications》读书笔记16
  12. 【Spring源码分析】.properties文件读取及占位符${...}替换源码解析
  13. 解读Batch Normalization
  14. Confluence 6 白名单表达式类型
  15. POJ 3713 Transferring Sylla【Tarjan求割点】
  16. 两个线程分别打印 1- 100,A 打印偶数, B打印奇数。
  17. (18)模型层 -ORM之msql 多表操作(字段的属性)
  18. [翻译]Elasticsearch重要文章之四:监控每个节点(jvm部分)
  19. 5 -- Hibernate的基本用法 --1 ORM和Hibernate
  20. NetCore入门篇:(四)Net Core项目启动文件Startup

热门文章

  1. WaitAny, WaitAll 和 SignalAndWait
  2. PHP使用mail()函数发送邮件流程以及注意事项
  3. 如何将maven项目导入myeclipse中
  4. jsoncpp 生成 json 字符串
  5. Js数组去重复取唯一值
  6. DataList与Repeater嵌套绑定
  7. 如何计算oracle数据库内存
  8. eclipse中tomcat加gc日志输出
  9. mongodb不同版本之间有很大的差异
  10. input绑定datapicker控件后input再绑定blur或者mouseout等问题