当Java程序运行时,其中的一些线程也正在执行。我们可以用第三方工具 jconsole 来查看Java进程中线程的执行情况和详细信息,这有助于我们对多线程编程的理解。jconsole 是我们Java的 jdk 自带的一个工具,我们使用它的步骤如下:
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() { @Override public 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,参考调用栈是一个合适的方式。