【Azure Developer】Windows中通过pslist命令查看到Java进程和线程信息,但为什么和代码中打印出来的进程号不一致呢?

通过PSLIST查看Windwos中的进程信息及线程信息

一:下载PSLIST小工具:https://docs.microsoft.com/en-us/sysinternals/downloads/pslist

二:解压到本地文件夹有,打开CMD。cd进入到pslist所在的文件夹,运行PSLIST命令,list处所有得进程信息

三:找到Java进程得进程号。通过pslist -dmx <pid>查看线程信息

如上,查看到的Thread ID为比较大线程号,如69992,60660,55160,70416,52032,53656,56176 ... ... 

但是,在Java的代码中,通过Thread.currentThread().getId()获取到的ID信息为21,22,23,24,25 ... ...  

对比发现,他们完全不一样! 这是怎么了呢?

在查看了Thread.CurrentThread()方法的定义后,初步理解为JVM为它分配的进程号并进行管理。而通过PSLIST工具查看到的java.exe中的进程,则为Windows系统为java资源所分配的进程号。

参考资料:

Get Current Thread Name And Thread ID in Java:https://knpcode.com/java-programs/get-current-thread-name-and-id-in-java/

Java.lang.Thread.getId() Method: https://www.tutorialspoint.com/java/lang/thread_getid.htm

当在复杂的环境中面临问题,格物之道需:浊而静之徐清,安以动之徐生。 云中,恰是如此!

原文地址:https://www.cnblogs.com/lulight/p/14551720.html