【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

 

posted @ 2021-03-17 20:24  路边两盏灯  阅读(191)  评论(0编辑  收藏  举报