摘要:獲取當(dāng)前進程以及所有進程的進程首先是獲取當(dāng)前運行的進程,這個是網(wǎng)上常見的,也就是程序自身將進程打印出來是一個在運行時管理和監(jiān)控的工廠類,它能提供很多管理的靜態(tài)接口,比如是虛擬機的運行時管理接口獲取所有正在運行著的進程獲取監(jiān)控主機取得所有在活
Java獲取當(dāng)前進程ID以及所有Java進程的進程ID 首先是獲取當(dāng)前Java運行的Java進程ID,這個是網(wǎng)上常見的,也就是Java程序自身將進程ID打印出來:
package com.test; import java.lang.management.ManagementFactory; import java.lang.management.RuntimeMXBean; public class Target { public static void main(String[] args) throws InterruptedException { System.out.println(getProcessID()); while(true) { Thread.sleep(10000); } } public static final int getProcessID() { RuntimeMXBean runtimeMXBean = ManagementFactory.getRuntimeMXBean(); System.out.println(runtimeMXBean.getName()); return Integer.valueOf(runtimeMXBean.getName().split("@")[0]) .intValue(); } }
ManagementFactory是一個在運行時管理和監(jiān)控Java VM的工廠類,它能提供很多管理VM的靜態(tài)接口,比如RuntimeMXBean;獲取所有正在運行著的Java進程
RuntimeMXBean是Java虛擬機的運行時管理接口.
package com.test; import java.util.HashSet; import java.util.Set; import sun.jvmstat.monitor.MonitoredHost; import sun.jvmstat.monitor.MonitoredVm; import sun.jvmstat.monitor.MonitoredVmUtil; import sun.jvmstat.monitor.VmIdentifier; public class ProcessID { public static void main(String[] args) throws Exception { // 獲取監(jiān)控主機 MonitoredHost local = MonitoredHost.getMonitoredHost("localhost"); // 取得所有在活動的虛擬機集合 Set> vmlist = new HashSet
MonitoredHost等類位于${JAVA_HOME}/lib/tools.jar
_
運行結(jié)果:
2752 ------> 5172 ------> com.test.Target 5308 ------> com.test.ProcessID直接根據(jù)類找到對應(yīng)Java進程ID的方法
package com.test; import java.net.URISyntaxException; import java.util.HashSet; import java.util.Set; import sun.jvmstat.monitor.MonitorException; import sun.jvmstat.monitor.MonitoredHost; import sun.jvmstat.monitor.MonitoredVm; import sun.jvmstat.monitor.MonitoredVmUtil; import sun.jvmstat.monitor.VmIdentifier; public class ProcessID { public static void main(String[] args) throws Exception { int pid = getProcess(Target.class); System.out.println("PID: "+pid); } public static int getProcess(Class> cls) throws MonitorException, URISyntaxException { if(cls == null) { return -1; } // 獲取監(jiān)控主機 MonitoredHost local = MonitoredHost.getMonitoredHost("localhost"); // 取得所有在活動的虛擬機集合 Set> vmlist = new HashSet根據(jù)類名稱找到對應(yīng)Java進程ID的方法
package com.example.demo; import sun.jvmstat.monitor.*; import java.net.URISyntaxException; import java.util.HashSet; import java.util.Set; public class ProcessID2 { public static void main(String[] args) throws Exception { int pid = getProcess("cn.usr.demo.DemoApplication"); System.out.println("PID: " + pid); } public static int getProcess(String cls) throws MonitorException, URISyntaxException { if (cls == null) { return -1; } // 獲取監(jiān)控主機 MonitoredHost local = MonitoredHost.getMonitoredHost("localhost"); // 取得所有在活動的虛擬機集合 Set> vmlist = new HashSet
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/8106.html
摘要:獲取當(dāng)前進程以及所有進程的進程首先是獲取當(dāng)前運行的進程,這個是網(wǎng)上常見的,也就是程序自身將進程打印出來是一個在運行時管理和監(jiān)控的工廠類,它能提供很多管理的靜態(tài)接口,比如是虛擬機的運行時管理接口獲取所有正在運行著的進程獲取監(jiān)控主機取得所有在活 Java獲取當(dāng)前進程ID以及所有Java進程的進程ID 首先是獲取當(dāng)前Java運行的Java進程ID,這個是網(wǎng)上常見的,也就是Java程序自身將...
摘要:父進程調(diào)用創(chuàng)建子進程。因而,一個進程的第一個線程會隨著這個進程的啟動而創(chuàng)建,這個線程被稱為該進程的主線程。另一方面,線程不可能獨立于進程存在。終止線程線程可以通過多種方式來終結(jié)同一個進程中的其他線程。 前言 不積跬步,無以至千里;不積小流,無以成江海。在學(xué)習(xí)Java多線程相關(guān)的知識前,我們首先需要去了解一點操作系統(tǒng)的進程、線程以及相關(guān)的基礎(chǔ)概念。 進程 通常,我們把一個程序的執(zhí)行稱為一...
摘要:系統(tǒng)創(chuàng)建好進程后,實際上就啟動執(zhí)行了該進程的主執(zhí)行線程。也就是說,對線程來說,進程相當(dāng)于一個容器,可以有許多線程同時在一個進程里執(zhí)行。默認(rèn)情況下,同一應(yīng)用程序下的所有組件都運行在相同的進程和線程一般稱為程序的主線程中。 一 前言 異步編程是android初學(xué)者的一個難點,卻也是始終不能繞過的一個坎??梢哉f幾乎每個app都逃不了網(wǎng)絡(luò)編程,而網(wǎng)絡(luò)編程又往往建立在異步的機制之上(你不應(yīng)該也無...
閱讀 1062·2019-08-30 12:57
閱讀 2150·2019-08-30 11:11
閱讀 2187·2019-08-29 15:20
閱讀 1879·2019-08-29 14:12
閱讀 3282·2019-08-28 17:51
閱讀 2387·2019-08-26 13:23
閱讀 809·2019-08-26 10:34
閱讀 3870·2019-08-23 12:37