> 文章列表 > 如何使用 jconsole 查看Java进程中线程的详细信息?

如何使用 jconsole 查看Java进程中线程的详细信息?

如何使用 jconsole 查看Java进程中线程的详细信息?

当Java程序运行时,其中的一些线程也正在执行。我们可以用第三方工具 jconsole 来查看Java进程中线程的执行情况和详细信息,这有助于我们对多线程编程的理解。jconsole 是我们Java的 jdk 自带的一个工具,我们使用它的步骤如下:

目录

1、找到Java JDK的bin目录,并打开

 2、在bin目录下找到 jconsole

3、创建多个Java线程,并运行Java进程

4、在程序启动的同时,打开 jconsole

5、选择自己写的Java程序,双击选中


1、找到Java JDK的bin目录,并打开

忘记 jdk 安装在哪里的朋友,可以通过本地 IDE 找到。以IDEA为例:

首先找到 IDEA 左上角的 File ,在下拉菜单找到 Project Structure,点击进入。

然后点击Edit

这里的JDK home path就是我们jdk的安装路径了。

 2、在bin目录下找到 jconsole

进入Java JDK的bin目录后,我们在里面找到 jconsole.exe 即可。这个工具就能帮助我们查看Java进程中线程的详情。

 注意,jconsole只能识别Java程序的进程,不能识别别的程序进程。

3、创建多个Java线程,并运行Java进程

打开IDEA,写下如下代码创建一个新的线程 t:

public class Test {public static void main(String[] args) {Thread t = new Thread(new Runnable() {@Overridepublic void run() {while(true) {System.out.println("I am Thread t!");}}});t.start();while(true) {System.out.println("I am Thread main!");}}
}

为了便于观察,我们在main线程与 t 线程中,都写上死循环。

启动程序。

4、在程序启动的同时,打开 jconsole

保持刚才的Java程序在运行状态,打开 jconsole,出现如下窗口。此时,这个“本地进程”一栏就显示了我们当前正在运行的Java程序。

必须确保我们的代码正在运行,因为只有正在运行的程序才是进程,才能被检测到。

注意,有的朋友打开 jconsole ,发现本地进程这个列表是空的,一个也没有。这应该是权限的问题,右键 jconsole ,选择以管理员运行,再打开即可。 

5、选择自己写的Java程序,双击选中

上面图中第二个程序Test是我们自己写的Java程序,我们双击选择它打开。此时可能会有这个弹窗警告。不管这个提示,直接选择不安全的连接即可。

 然后选择左上角,线程标签页。

在线程标签页的左下角,就显示了我们当前进程中的所有线程,实际上它们并不只有我们代码中的两个主线程和 t 线程,而是还有一些别的进程。

这个界面就非常直观地向我们展示了“进程包含线程”这一结论。

除了上面的 main 主线程,和 Thread-0 我们自定义的线程,剩下的都是 JVM 自己创建的。JVM的功能是非常复杂的,当程序运行时,它会创建一些别的线程如记录JVM状态、进行垃圾回收等辅助程序运行。

我们可以单击线程名来查看当前线程的情况。

 

其中,堆栈跟踪是一个关键信息。它描述的是当前线程中的代码执行到哪里了。当多线程编程时,如果代码发生bug,参考调用栈是一个合适的方式。