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

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

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

https://img2020.cnblogs.com/blog/2127802/202103/2127802-20210317194830268-79586300.gif

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

https://img2020.cnblogs.com/blog/2127802/202103/2127802-20210317194845510-606750638.gif

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

https://img2020.cnblogs.com/blog/2127802/202103/2127802-20210317195926304-1039070315.png 但是,在Java的代码中,通过Thread.currentThread().getId()获取到的ID信息为21,22,23,24,25 ... ...

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

在查看了Thread.CurrentThread()方法的定义后,初步理解为JVM为它分配的进程号并进行管理。而通过PSLIST工具查看到的java.exe中的进程,则为Windows系统为java资源所分配的进程号。 https://img2020.cnblogs.com/blog/2127802/202103/2127802-20210317201707563-1075454278.png

参考资料:

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

⚠️ **GitHub.com Fallback** ⚠️