国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

在Java應(yīng)用程序中監(jiān)視CPU的使用

瀏覽:4日期:2024-06-19 11:00:40
內(nèi)容: 怎樣在Java中得到CPU的使用情況呢?這兒同時(shí)有一個(gè)好消息和一個(gè)壞消息。壞消息是不能使用純Java的方法得到CPU的使用。沒有這方面的直接的API。一個(gè)建議的替代方法是通過Runtime.exec()確定JVM的進(jìn)程ID(PID),調(diào)用外部的、平臺相關(guān)的命令,例如ps,然后在運(yùn)行結(jié)果中解析出感興趣的PID。但是,這種方法并不理想。 好消息是,可以采用一個(gè)更為可靠的方案:跳出Java,寫幾行C代碼,然后通過JNI進(jìn)行整合。下面我將向你展示編寫一個(gè)Win32平臺的簡單的JNI庫是多么簡單。 一般來說,JNI有點(diǎn)復(fù)雜。但是,如果你僅僅單向調(diào)用--從Java調(diào)用本地代碼,并且僅使用基本型進(jìn)行通訊--事情還是很簡單的。有許多JNI方面的學(xué)習(xí)資料,所以這兒我就不介紹JNI的基礎(chǔ)了。我僅介紹我的實(shí)現(xiàn)步驟。一、在Java中聲明JNI方法開始,我創(chuàng)建一個(gè)聲明了本地方法的類com.vladium.utils.SystemInformation,該方法返回當(dāng)前進(jìn)程已使用的CPU的毫秒數(shù)。public staticnative long getProcessCPUTime();使用JDK內(nèi)置的javah工具產(chǎn)生將來本地代碼實(shí)現(xiàn)使用的C頭。JNIEXPORT jlong JNICALLJava_com_vladium_utils_SystemInformation_getProcessCPUTime (JNIEnv * env, jclass cls)二、本地方法實(shí)現(xiàn)在大多數(shù)的Win32平臺上,該方法可以使用GetProcessTimes()系統(tǒng)調(diào)用實(shí)現(xiàn),差不多僅需要3行代碼就可以了:JNIEXPORT jlong JNICALLJava_com_vladium_utils_SystemInformation_getProcessCPUTime (JNIEnv * env, jclass cls){ FILETIME creationTime, exitTime, kernelTime, userTime; GetProcessTimes (s_currentProcess, & creationTime, & exitTime, & kernelTime, & userTime); return (jlong) ((fileTimeToInt64 (& kernelTime) + fileTimeToInt64 (& userTime)) / (s_numberOfProcessors * 10000));}該方法首先累加用于執(zhí)行當(dāng)前進(jìn)程的核心和用戶代碼耗費(fèi)的時(shí)間,除以處理器的數(shù)目,并把結(jié)果轉(zhuǎn)換到毫秒。fileTimeToInt64()是一個(gè)輔助函數(shù),用于把FILETIME結(jié)構(gòu)的數(shù)據(jù)轉(zhuǎn)換為64位的整數(shù)。s_currentProcess 和 s_numberOfProcessors是全局變量,當(dāng)JVM裝載本地庫時(shí)即初始化。static HANDLE s_currentProcess;static int s_numberOfProcessors;JNIEXPORT jint JNICALLJNI_OnLoad (JavaVM * vm, void * reserved){ SYSTEM_INFO systemInfo; s_currentProcess = GetCurrentProcess (); GetSystemInfo (& systemInfo); s_numberOfProcessors = systemInfo.dwNumberOfProcessors; return JNI_VERSION_1_2;}注意,如果你在UNIX平臺上實(shí)現(xiàn)getProcessCPUTime(),你應(yīng)該以getrusage系統(tǒng)調(diào)用開始。三、調(diào)用本地方法回到Java中,在SystemInformation類中,裝載本地庫(silib.dll on Win32)最好通過靜態(tài)初始化代碼塊完成。 private static final String SILIB = 'silib'; static { try { System.loadLibrary (SILIB); } catch (UnsatisfiedLinkError e) { System.out.println ('native lib '' + SILIB + '' not found in 'java.library.path': ' + System.getProperty ('java.library.path')); throw e; // re-throw } }注意,getProcessCPUTime()返回自JVM進(jìn)程創(chuàng)建以來使用的CPU時(shí)間。就這個(gè)數(shù)據(jù)本身而言,對于這兒并沒有太多的用處。我需要更有用的Java方法來記錄不同的時(shí)刻的數(shù)據(jù)快照(data snapshots),并報(bào)告任何兩個(gè)時(shí)間點(diǎn)之間CPU的使用。 public static final class CPUUsageSnapshot { private CPUUsageSnapshot (long time, long CPUTime) { m_time = time; m_CPUTime = CPUTime; } public final long m_time, m_CPUTime; } // end of nested class public static CPUUsageSnapshot makeCPUUsageSnapshot () { return new CPUUsageSnapshot (System.currentTimeMillis (), getProcessCPUTime ()); } public static double getProcessCPUUsage (CPUUsageSnapshot start, CPUUsageSnapshot end) { return ((double)(end.m_CPUTime - start.m_CPUTime)) / (end.m_time - start.m_time); }四、一個(gè)簡單的CPU監(jiān)視程序“CPU監(jiān)視API基本就完成了!最后,我創(chuàng)建了一個(gè)singleton的線程類CPUUsageThread,它自動地每過一個(gè)時(shí)間間隔(默認(rèn)是0.5秒)就拍下一個(gè)數(shù)據(jù)快照,并報(bào)告給所有的CPU使用事件的監(jiān)聽者(Observer模式)。 public void run () { while (! isInterrupted ()) { final SystemInformation.CPUUsageSnapshot snapshot = SystemInformation.makeCPUUsageSnapshot (); notifyListeners (snapshot); try { sleep (sleepTime); } catch (InterruptedException e) { return; } } }CPUmon類是一個(gè)示例的監(jiān)聽器,僅簡單地把CPU的使用情況打印輸出到System.out。 public static void main (String [] args) throws Exception { if (args.length == 0) throw new IllegalArgumentException ('usage: CPUmon '); CPUUsageThread monitor = CPUUsageThread.getCPUThreadUsageThread (); CPUmon _this = new CPUmon (); Class app = Class.forName (args [0]); Method appmain = app.getMethod ('main', new Class [] {String[].class}); String [] appargs = new String [args.length - 1] System.arraycopy (args, 1, appargs, 0, appargs.length); monitor.addUsageEventListener (_this); monitor.start (); appmain.invoke (null, new Object [] {appargs}); }另外,為了能夠在啟動要監(jiān)視的應(yīng)用程序之前開始CPUUsageThread,CPUmon.main()包裝了另一個(gè)Java主類。作為演示,我運(yùn)行CPUmon和JDK1.3.1的SwingSet2示例程序(不要忘了把silib.dll安裝到OS的PATH環(huán)境變量或者java.library.path系統(tǒng)屬性所覆蓋的路徑下):>java -Djava.library.path=. -cp silib.jar;(my JDK install dir)demojfcSwingSet2SwingSet2.jar CPUmon SwingSet2[PID: 339] CPU usage: 46.8%[PID: 339] CPU usage: 51.4%[PID: 339] CPU usage: 54.8%(while loading, the demo uses nearly 100% of one of the two CPUs on my machine)...[PID: 339] CPU usage: 46.8%[PID: 339] CPU usage: 0%[PID: 339] CPU usage: 0%(the demo finished loading all of its panels and is mostly idle)...[PID: 339] CPU usage: 100%[PID: 339] CPU usage: 98.4%[PID: 339] CPU usage: 97%(I switched to the ColorChooserDemo panel which ran a CPU-intensiveanimation that used both of my CPUs)...[PID: 339] CPU usage: 81.4%[PID: 339] CPU usage: 50%[PID: 339] CPU usage: 50%(I used Windows NT Task Manager to adjust the CPU affinity for the'java' process to use a single CPU)...當(dāng)然,我也可以通過任務(wù)管理器查看到CPU使用信息,這兒的要點(diǎn)是現(xiàn)在我們可以以編程方式記錄該信息。對于長時(shí)間運(yùn)行測試和服務(wù)器應(yīng)用診斷程序,遲早會派上用場。本文附帶的完整的庫中添加了其它一些有用的本地方法,其中一個(gè)可以得到進(jìn)程的PID(用于與外部工具整合)。from-javaworld.com javaresearch翻譯 Java, java, J2SE, j2se, J2EE, j2ee, J2ME, j2me, ejb, ejb3, JBOSS, jboss, spring, hibernate, jdo, struts, webwork, ajax, AJAX, mysql, MySQL, Oracle, Weblogic, Websphere, scjp, scjd
標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 国产精品免费aⅴ片在线观看 | 美女一级片| 国产黄色一级毛片 | 中文字幕一区二区三区亚洲精品 | 欧美福利一区二区三区 | 欧美怡红院高清在线 | 久久久久久99精品 | 免费女人18毛片a级毛片视频 | 国内精品久久久久久久久蜜桃 | 中文字幕亚洲精品第一区 | 国产精品久久久久三级 | 国产精品中文字幕在线观看 | 手机看片1024精品国产 | 一级片网址 | 免费特黄一区二区三区视频一 | 韩国19禁主播裸免费福利 | a级成人高清毛片 | 在线国产欧美 | 美女黄影院 | 久久不雅视频 | 欧美视频一区 | 亚洲福利精品一区二区三区 | 日韩一级精品久久久久 | 国产美女自拍视频 | 久草在线资源 | 日本手机在线视频 | 色在线免费视频 | 亚洲 欧美 激情 另类 校园 | 久久99国产精一区二区三区! | 视频二区好吊色永久视频 | 亚洲无吗| 精品久久网 | 9191精品国产免费不久久 | 日本wwxx色视频 | 蝴蝶成人世界第八影院 | 1级a的观看视频 | 精品视频一区二区三区在线观看 | 日本精品高清一区二区不卡 | 欧美一级毛片免费看视频 | 全部免费的毛片视频观看 | 女人夜色黄网在线观看 |