ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

如何确定Java程序中哪个线程最耗CPU资源

2019-07-21 19:03:11  阅读:359  来源: 互联网

标签:lang Java Thread prio nid 线程 最耗 java


文章目录

一、Windows操作系统

  1. 执行Java程序,如下代码:
    public class Test {
    
    	public static void main(String[] args) {
    		new Thread(new Task()).start();
    	}
    	
    	static class Task implements Runnable {
    		
    		@Override
    		public void run() {
    			while (true) {
    			}
    		}
    	}
    }
    
  2. 执行jps命令获取Java程序进程id,这里获取的进程id为4844
  3. 安装并启动进程管理:下载地址:http://technet.microsoft.com/en-us/sysinternals/bb896653.aspx——>解压运行,如下图所示:在这里插入图片描述
  4. 在上图寻找进程id为4844的进程(上图红框框起处)——>鼠标浮在该进程信息上——>鼠标右键——>选择“Properties…”,出现下图:
    在这里插入图片描述
  5. 选择 Threads 选项卡——>找到最耗CPU资源的线程——>将该线程tid转为十六进制,如5184对应十六进制为1440;
  6. 执行jstack 4844命令输出4844进程内各线程信息——>在该结果中寻找nid为1440的线程,如下结果:
    2019-07-11 20:44:02
    Full thread dump Java HotSpot(TM) Client VM (25.131-b11 mixed mode, sharing):
    
    "DestroyJavaVM" #9 prio=5 os_prio=0 tid=0x00eac400 nid=0x1724 waiting on condition [0x00000000]
       java.lang.Thread.State: RUNNABLE
    
    "Thread-0" #8 prio=5 os_prio=0 tid=0x159a6c00 nid=0x1440 runnable [0x1538f000]
       java.lang.Thread.State: RUNNABLE
    	at Test$Task.run(Test.java:12)
    	at java.lang.Thread.run(Thread.java:748)
    
    "Service Thread" #7 daemon prio=9 os_prio=0 tid=0x00dd6400 nid=0x6b8 runnable [0x00000000]
       java.lang.Thread.State: RUNNABLE
    
    "C1 CompilerThread0" #6 daemon prio=9 os_prio=2 tid=0x00dcf800 nid=0x2238 waiting on condition [0x00000000]
       java.lang.Thread.State: RUNNABLE
    
    "Attach Listener" #5 daemon prio=5 os_prio=2 tid=0x00dce800 nid=0x21a8 waiting on condition [0x00000000]
       java.lang.Thread.State: RUNNABLE
    
    "Signal Dispatcher" #4 daemon prio=9 os_prio=2 tid=0x00dcc800 nid=0xd68 runnable [0x00000000]
       java.lang.Thread.State: RUNNABLE
    
    "Finalizer" #3 daemon prio=8 os_prio=1 tid=0x00db3c00 nid=0x1570 in Object.wait() [0x0112f000]
       java.lang.Thread.State: WAITING (on object monitor)
    	at java.lang.Object.wait(Native Method)
    	- waiting on <0x04608978> (a java.lang.ref.ReferenceQueue$Lock)
    	at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:143)
    	- locked <0x04608978> (a java.lang.ref.ReferenceQueue$Lock)
    	at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:164)
    	at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:209)
    
    "Reference Handler" #2 daemon prio=10 os_prio=2 tid=0x00d56800 nid=0x1be0 in Object.wait() [0x0109f000]
       java.lang.Thread.State: WAITING (on object monitor)
    	at java.lang.Object.wait(Native Method)
    	- waiting on <0x04606a90> (a java.lang.ref.Reference$Lock)
    	at java.lang.Object.wait(Object.java:502)
    	at java.lang.ref.Reference.tryHandlePending(Reference.java:191)
    	- locked <0x04606a90> (a java.lang.ref.Reference$Lock)
    	at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:153)
    
    "VM Thread" os_prio=2 tid=0x00d52c00 nid=0x15f0 runnable 
    
    "VM Periodic Task Thread" os_prio=2 tid=0x159a0800 nid=0x2538 waiting on condition 
    
    JNI global references: 6
    
  7. 根据线程提示信息,确定Java程序哪个类哪个位置导致了该线程最耗CPU资源——>找到类后打开代码,分析程序,思考解决方案!

二、Linux操作系统:

  1. 通过jps命令找出Java程序进程ID:
  2. 通过top -Hp pid命令找出该进程内CPU时间最长线程id,将该线程id转换为十六进制;
  3. 通过jstack pid命令输出pid进程内各线程信息,在众多线程中,nid的值为第二步得到的十六进制的线程即是需要格外“关照”的线程;

标签:lang,Java,Thread,prio,nid,线程,最耗,java
来源: https://blog.csdn.net/qq_41135704/article/details/96747596

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有