博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
通过top命令和thread dump查看JAVA线程死循环的案例
阅读量:7071 次
发布时间:2019-06-28

本文共 472 字,大约阅读时间需要 1 分钟。

这篇文章是由一个面试的问题引出的。面试官问曰:“尔可知如何定位JAVA程序的死循环?”。思虑良久,未有良策,回来查阅了下资料,经过一番曲折感觉自己解决问题的能力又提高了不少。以下是个例子,不一定很合适但足以说明一些问题。

1、查看进程ID:

[resin_access@172 ~]$ jps

3230 jar

2、按CPU使用率展示当前JAVA程序的所有线程:

其实这个地方按CPU的使用率来判定还不太好理解,以运行时间来判定可能更能说明问题些,具体的top命令可参考另外一篇文章()。

3、将运行时间最长的本地线程ID(3244)转成16进制为0xcac。

4、生成线程堆栈日志文件jstack -l 3230 > jstack.log;

5、打开堆栈日志搜索“0xcac”:

很容易的就找到了无限循环的调用线程堆栈。

注:死循环的那几个方法命名不代表任何意义纯粹是随手复制,主要是为了展示调用过程,将就着看看算了。

本文转自 古道卿 51CTO博客,原文链接:http://blog.51cto.com/gudaoqing/1439986

转载地址:http://cjell.baihongyu.com/

你可能感兴趣的文章
多种替身邮方法总结!
查看>>
沟通比文档更有力
查看>>
在页面头部<!DOCTYPE html ....> 前面不能有任何输出
查看>>
hdu 2102 A计划(双层BFS)(具体解释)
查看>>
大型机器学习
查看>>
FluentNhibernate 不支持存储过程
查看>>
Python 修改电脑DNS
查看>>
复杂 Listview 显示 多个样式
查看>>
[Unity3D]Unity3D游戏开发之角色控制漫谈
查看>>
git branch merge到master
查看>>
EJB--事务管理 .
查看>>
在vmware里面免费安装纯净的xp虚拟机
查看>>
什么是RESTfull?理解RESTfull架构【转】
查看>>
linux lsof命令详解
查看>>
MySQL中concat函数
查看>>
代理模式
查看>>
Linux命令 cat命令
查看>>
poj1007 逆序数 排序
查看>>
周末轻松话卷积(上)
查看>>
【转】对C# 中堆栈,堆,值类型,引用类型的理解
查看>>