亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

java不用jni,也可以獲得當前系統性能信息

2019-11-17 04:10:40
字體:
來源:轉載
供稿:網友

最近做個項目,就是要取得cpu占有率等等的系統信息,一開始以為要用動態鏈接庫了,但后來發現可以像下面這樣做,不去調用jni,這樣省去了很多看新技術的時間o(∩_∩)o...

java中,可以獲得總的物理內存、剩余的物理內存、已使用的物理內存等信息,下面例子可以取得這些信息,并且獲得在Windows下的內存使用率。
     首先編寫一個MonitorInfoBean類,用來裝載監控的一些信息,包括物理內存、剩余的物理內存、已使用的物理內存、內存使用率等字段,該類的代碼如下:

Java代碼 
package  com.amgkaka.performance;  
  
/** */ /**  
 * 監視信息的JavaBean類.  
 * @author  amg  
 * @version 1.0   
 * Creation date: 2008-4-25 - 上午10:37:00  
 */   
public   class  MonitorInfoBean {  
    /** */ /** 可使用內存. */   
    PRivate   long  totalMemory;  
      
    /** */ /** 剩余內存. */   
    private   long  freeMemory;  
      
    /** */ /** 最大可使用內存. */   
    private   long  maxMemory;  
      
    /** */ /** 操作系統. */   
    private  String osName;  
      
    /** */ /** 總的物理內存. */   
    private   long  totalMemorySize;  
      
    /** */ /** 剩余的物理內存. */   
    private   long  freePhysicalMemorySize;  
      
    /** */ /** 已使用的物理內存. */   
    private   long  usedMemory;  
      
    /** */ /** 線程總數. */   
    private   int  totalThread;  
      
    /** */ /** cpu使用率. */   
    private   double  cpuRatio;  
  
    public   long  getFreeMemory() {  
        return  freeMemory;  
    }  
  
    public   void  setFreeMemory( long  freeMemory) {  
        this .freeMemory = freeMemory;  
    }  
  
    public   long  getFreePhysicalMemorySize() {  
        return  freePhysicalMemorySize;  
    }  
  
    public   void  setFreePhysicalMemorySize( long  freePhysicalMemorySize) {  
        this .freePhysicalMemorySize = freePhysicalMemorySize;  
    }  
  
    public   long  getMaxMemory() {  
        return  maxMemory;  
    }  
  
    public   void  setMaxMemory( long  maxMemory) {  
        this .maxMemory = maxMemory;  
    }  
  
    public  String getOsName() {  
        return  osName;  
    }  
  
    public   void  setOsName(String osName) {  
        this .osName = osName;  
    }  
  
    public   long  getTotalMemory() {  
        return  totalMemory;  
    }  
  
    public   void  setTotalMemory( long  totalMemory) {  
        this .totalMemory = totalMemory;  
    }  
  
    public   long  getTotalMemorySize() {  
        return  totalMemorySize;  
    }  
  
    public   void  setTotalMemorySize( long  totalMemorySize) {  
        this .totalMemorySize = totalMemorySize;  
    }  
  
    public   int  getTotalThread() {  
        return  totalThread;  
    }  
  
    public   void  setTotalThread( int  totalThread) {  
        this .totalThread = totalThread;  
    }  
  
    public   long  getUsedMemory() {  
        return  usedMemory;  
    }  
  
    public   void  setUsedMemory( long  usedMemory) {  
        this .usedMemory = usedMemory;  
    }  
  
    public   double  getCpuRatio() {  
        return  cpuRatio;  
    }  
  
    public   void  setCpuRatio( double  cpuRatio) {  
        this .cpuRatio = cpuRatio;  
    }  
}  
package com.amgkaka.performance;

/** *//**
 * 監視信息的JavaBean類.
 * @author  amg
 * @version 1.0
 * Creation date: 2008-4-25 - 上午10:37:00
 */
public class MonitorInfoBean {
    /** *//** 可使用內存. */
    private long totalMemory;
   
    /** *//** 剩余內存. */
    private long freeMemory;
   
    /** *//** 最大可使用內存. */
    private long maxMemory;
   
    /** *//** 操作系統. */
    private String osName;
   
    /** *//** 總的物理內存. */
    private long totalMemorySize;
   
    /** *//** 剩余的物理內存. */
    private long freePhysicalMemorySize;
   
    /** *//** 已使用的物理內存. */
    private long usedMemory;
   
    /** *//** 線程總數. */
    private int totalThread;
   
    /** *//** cpu使用率. */
    private double cpuRatio;

    public long getFreeMemory() {
        return freeMemory;
    }

    public void setFreeMemory(long freeMemory) {
        this.freeMemory = freeMemory;
    }

    public long getFreePhysicalMemorySize() {
        return freePhysicalMemorySize;
    }

    public void setFreePhysicalMemorySize(long freePhysicalMemorySize) {
        this.freePhysicalMemorySize = freePhysicalMemorySize;
    }

    public long getMaxMemory() {
        return maxMemory;
    }

    public void setMaxMemory(long maxMemory) {
        this.maxMemory = maxMemory;
    }

    public String getOsName() {
        return osName;
    }

    public void setOsName(String osName) {
        this.osName = osName;
    }

    public long getTotalMemory() {
        return totalMemory;
    }

    public void setTotalMemory(long totalMemory) {
        this.totalMemory = totalMemory;
    }

    public long getTotalMemorySize() {
        return totalMemorySize;
    }

    public void setTotalMemorySize(long totalMemorySize) {
        this.totalMemorySize = totalMemorySize;
    }

    public int getTotalThread() {
        return totalThread;
    }

    public void setTotalThread(int totalThread) {
        this.totalThread = totalThread;
    }

    public long getUsedMemory() {
        return usedMemory;
    }

    public void setUsedMemory(long usedMemory) {
        this.usedMemory = usedMemory;
    }

    public double getCpuRatio() {
        return cpuRatio;
    }

    public void setCpuRatio(double cpuRatio) {
        this.cpuRatio = cpuRatio;
    }
}
接著編寫一個獲得當前的監控信息的接口,該類的代碼如下所示:

Java代碼 
package  com.amgkaka.performance;  
  
/** */ /**  
 * 獲取系統信息的業務邏輯類接口.  
 * @author amg * @version 1.0   
 * Creation date: 2008-3-11 - 上午10:06:06  
 */   
public   interface  IMonitorService {  
    /** */ /**  
     * 獲得當前的監控對象.  
     * @return 返回構造好的監控對象  
     * @throws Exception  
     * @author amgkaka  
     * Creation date: 2008-4-25 - 上午10:45:08  
     */   
    public  MonitorInfoBean getMonitorInfoBean()  throws  Exception;  
  
}  
package com.amgkaka.performance;

/** *//**
 * 獲取系統信息的業務邏輯類接口.
 * @author amg * @version 1.0
 * Creation date: 2008-3-11 - 上午10:06:06
 */
public interface IMonitorService {
    /** *//**
     * 獲得當前的監控對象.
     * @return 返回構造好的監控對象
     * @throws Exception
     * @author amgkaka
     * Creation date: 2008-4-25 - 上午10:45:08
     */
    public MonitorInfoBean getMonitorInfoBean() throws Exception;

}  該類的實現類MonitorServiceImpl如下所示:

Java代碼 
package  com.amgkaka.performance;  
  
import  java.io.InputStreamReader;  
import  java.io.LineNumberReader;  
  
import  sun.management.ManagementFactory;  
  
import  com.sun.management.OperatingSystemMXBean;  
  
/** */ /**  
 * 獲取系統信息的業務邏輯實現類.  
 * @author amg * @version 1.0 Creation date: 2008-3-11 - 上午10:06:06  
 */   
public   class  MonitorServiceImpl  implements  IMonitorService {  
    //可以設置長些,防止讀到運行此次系統檢查時的cpu占用率,就不準了   
    private   static   final   int  CPUTIME =  5000 ;  
  
    private   static   final   int  PERCENT =  100 ;  
  
    private   static   final   int  FAULTLENGTH =  10 ;  
  
    /** */ /**  
     * 獲得當前的監控對象.  
     * @return 返回構造好的監控對象  
     * @throws Exception  
     * @author amg     * Creation date: 2008-4-25 - 上午10:45:08  
     */   
    public  MonitorInfoBean getMonitorInfoBean()  throws  Exception {  
        int  kb =  1024 ;  
          
        // 可使用內存   
        long  totalMemory = Runtime.getRuntime().totalMemory() / kb;  
        // 剩余內存   
        long  freeMemory = Runtime.getRuntime().freeMemory() / kb;  
        // 最大可使用內存   
        long  maxMemory = Runtime.getRuntime().maxMemory() / kb;  
  
        OperatingSystemMXBean osmxb = (OperatingSystemMXBean) ManagementFactory  
                .getOperatingSystemMXBean();  
  
        // 操作系統   
        String osName = System.getProperty("os.name" );  
        // 總的物理內存   
        long  totalMemorySize = osmxb.getTotalPhysicalMemorySize() / kb;  
        // 剩余的物理內存   
        long  freePhysicalMemorySize = osmxb.getFreePhysicalMemorySize() / kb;  
        // 已使用的物理內存   
        long  usedMemory = (osmxb.getTotalPhysicalMemorySize() - osmxb  
                .getFreePhysicalMemorySize())  
                / kb;  
  
        // 獲得線程總數   
        ThreadGroup parentThread;  
        for  (parentThread = Thread.currentThread().getThreadGroup(); parentThread  
                .getParent() != null ; parentThread = parentThread.getParent())  
            ;  
        int  totalThread = parentThread.activeCount();  
  
        double  cpuRatio =  0 ;  
        if  (osName.toLowerCase().startsWith( "windows" )) {  
            cpuRatio = this .getCpuRatioForWindows();  
        }  
          
        // 構造返回對象   
        MonitorInfoBean infoBean = new  MonitorInfoBean();  
        infoBean.setFreeMemory(freeMemory);  
        infoBean.setFreePhysicalMemorySize(freePhysicalMemorySize);  
        infoBean.setMaxMemory(maxMemory);  
        infoBean.setOsName(osName);  
        infoBean.setTotalMemory(totalMemory);  
        infoBean.setTotalMemorySize(totalMemorySize);  
        infoBean.setTotalThread(totalThread);  
        infoBean.setUsedMemory(usedMemory);  
        infoBean.setCpuRatio(cpuRatio);  
        return  infoBean;  
    }  
  
    /** */ /**  
     * 獲得CPU使用率.  
     * @return 返回cpu使用率  
     * @author amg     * Creation date: 2008-4-25 - 下午06:05:11  
     */   
    private   double  getCpuRatioForWindows() {  
        try  {  
            String procCmd = System.getenv("windir" )  
                    + "//system32//wbem//wmic.exe process get Caption,CommandLine,"   
                    + "KernelModeTime,ReadOperationCount,ThreadCount,UserModeTime,WriteOperationCount" ;  
            // 取進程信息   
            long [] c0 = readCpu(Runtime.getRuntime().exec(procCmd));  
            Thread.sleep(CPUTIME);  
            long [] c1 = readCpu(Runtime.getRuntime().exec(procCmd));  
            if  (c0 !=  null  && c1 !=  null ) {  
                long  idletime = c1[ 0 ] - c0[ 0 ];  
                long  busytime = c1[ 1 ] - c0[ 1 ];  
                return  Double.valueOf(  
                        PERCENT * (busytime) / (busytime + idletime))  
                        .doubleValue();  
            } else  {  
                return   0.0 ;  
            }  
        } catch  (Exception ex) {  
            ex.printStackTrace();  
            return   0.0 ;  
        }  
    }  
  
    /** */ /**  
     * 讀取CPU信息.  
     * @param proc  
     * @return  
     * @author amg     * Creation date: 2008-4-25 - 下午06:10:14  
     */   
    private   long [] readCpu( final  Process proc) {  
        long [] retn =  new   long [ 2 ];  
        try  {  
            proc.getOutputStream().close();  
            InputStreamReader ir = new  InputStreamReader(proc.getInputStream());  
            LineNumberReader input = new  LineNumberReader(ir);  
            String line = input.readLine();  
            if  (line ==  null  || line.length() < FAULTLENGTH) {  
                return   null ;  
            }  
            int  capidx = line.indexOf( "Caption" );  
            int  cmdidx = line.indexOf( "CommandLine" );  
            int  rocidx = line.indexOf( "ReadOperationCount" );  
            int  umtidx = line.indexOf( "UserModeTime" );  
            int  kmtidx = line.indexOf( "KernelModeTime" );  
            int  wocidx = line.indexOf( "WriteOperationCount" );  
            long  idletime =  0 ;  
            long  kneltime =  0 ;  
            long  usertime =  0 ;  
            while  ((line = input.readLine()) !=  null ) {  
                if  (line.length() < wocidx) {  
                    continue ;  
                }  
                // 字段出現順序:Caption,CommandLine,KernelModeTime,ReadOperationCount,   
                // ThreadCount,UserModeTime,WriteOperation   
                String caption = Bytes.substring(line, capidx, cmdidx - 1 )  
                        .trim();  
                String cmd = Bytes.substring(line, cmdidx, kmtidx - 1 ).trim();  
                if  (cmd.indexOf( "wmic.exe" ) >=  0 ) {  
                    continue ;  
                }  
                // log.info("line="+line);   
                if  (caption.equals( "System Idle Process" )  
                        || caption.equals("System" )) {  
                    idletime += Long.valueOf(  
                            Bytes.substring(line, kmtidx, rocidx - 1 ).trim())  
                            .longValue();  
                    idletime += Long.valueOf(  
                            Bytes.substring(line, umtidx, wocidx - 1 ).trim())  
                            .longValue();  
                    continue ;  
                }  
  
                kneltime += Long.valueOf(  
                        Bytes.substring(line, kmtidx, rocidx - 1 ).trim())  
                        .longValue();  
                usertime += Long.valueOf(  
                        Bytes.substring(line, umtidx, wocidx - 1 ).trim())  
                        .longValue();  
            }  
            retn[0 ] = idletime;  
            retn[1 ] = kneltime + usertime;  
            return  retn;  
        } catch  (Exception ex) {  
            ex.printStackTrace();  
        } finally  {  
            try  {  
                proc.getInputStream().close();  
            } catch  (Exception e) {  
                e.printStackTrace();  
            }  
        }  
        return   null ;  
    }  
      
    /** */ /**  
     * 測試方法.  
     * @param args  
     * @throws Exception  
     * @author amg     * Creation date: 2008-4-30 - 下午04:47:29  
     */   
    public   static   void  main(String[] args)  throws  Exception {  
        IMonitorService service = new  MonitorServiceImpl();  
        MonitorInfoBean monitorInfo = service.getMonitorInfoBean();  
        System.out.println("cpu占有率="  + monitorInfo.getCpuRatio());  
          
        System.out.println("可使用內存="  + monitorInfo.getTotalMemory());  
        System.out.println("剩余內存="  + monitorInfo.getFreeMemory());  
        System.out.println("最大可使用內存="  + monitorInfo.getMaxMemory());  
          
        System.out.println("操作系統="  + monitorInfo.getOsName());  
        System.out.println("總的物理內存="  + monitorInfo.getTotalMemorySize() +  "kb" );  
        System.out.println("剩余的物理內存="  + monitorInfo.getFreeMemory() +  "kb" );  
        System.out.println("已使用的物理內存="  + monitorInfo.getUsedMemory() +  "kb" );  
        System.out.println("線程總數="  + monitorInfo.getTotalThread() +  "kb" );  
    }  
}  
package com.amgkaka.performance;

import java.io.InputStreamReader;
import java.io.LineNumberReader;

import sun.management.ManagementFactory;

import com.sun.management.OperatingSystemMXBean;

/** *//**
 * 獲取系統信息的業務邏輯實現類.
 * @author amg * @version 1.0 Creation date: 2008-3-11 - 上午10:06:06
 */
public class MonitorServiceImpl implements IMonitorService {
    //可以設置長些,防止讀到運行此次系統檢查時的cpu占用率,就不準了
    private static final int CPUTIME = 5000;

    private static final int PERCENT = 100;

    private static final int FAULTLENGTH = 10;

    /** *//**
     * 獲得當前的監控對象.
     * @return 返回構造好的監控對象
     * @throws Exception
     * @author amg     * Creation date: 2008-4-25 - 上午10:45:08
     */
    public MonitorInfoBean getMonitorInfoBean() throws Exception {
        int kb = 1024;
       
        // 可使用內存
        long totalMemory = Runtime.getRuntime().totalMemory() / kb;
        // 剩余內存
        long freeMemory = Runtime.getRuntime().freeMemory() / kb;
        // 最大可使用內存
        long maxMemory = Runtime.getRuntime().maxMemory() / kb;

        OperatingSystemMXBean osmxb = (OperatingSystemMXBean) ManagementFactory
                .getOperatingSystemMXBean();

        // 操作系統
        String osName = System.getProperty("os.name");
        // 總的物理內存
        long totalMemorySize = osmxb.getTotalPhysicalMemorySize() / kb;
        // 剩余的物理內存
        long freePhysicalMemorySize = osmxb.getFreePhysicalMemorySize() / kb;
        // 已使用的物理內存
        long usedMemory = (osmxb.getTotalPhysicalMemorySize() - osmxb
                .getFreePhysicalMemorySize())
                / kb;

        // 獲得線程總數
        ThreadGroup parentThread;
        for (parentThread = Thread.currentThread().getThreadGroup(); parentThread
                .getParent() != null; parentThread = parentThread.getParent())
            ;
        int totalThread = parentThread.activeCount();

        double cpuRatio = 0;
        if (osName.toLowerCase().startsWith("windows")) {
            cpuRatio = this.getCpuRatioForWindows();
        }
       
        // 構造返回對象
        MonitorInfoBean infoBean = new MonitorInfoBean();
        infoBean.setFreeMemory(freeMemory);
        infoBean.setFreePhysicalMemorySize(freePhysicalMemorySize);
        infoBean.setMaxMemory(maxMemory);
        infoBean.setOsName(osName);
        infoBean.setTotalMemory(totalMemory);
        infoBean.setTotalMemorySize(totalMemorySize);
        infoBean.setTotalThread(totalThread);
        infoBean.setUsedMemory(usedMemory);
        infoBean.setCpuRatio(cpuRatio);
        return infoBean;
    }

    /** *//**
     * 獲得CPU使用率.
     * @return 返回cpu使用率
     * @author amg     * Creation date: 2008-4-25 - 下午06:05:11
     */
    private double getCpuRatioForWindows() {
        try {
            String procCmd = System.getenv("windir")
                    + "//system32//wbem//wmic.exe process get Caption,CommandLine,"
                    + "KernelModeTime,ReadOperationCount,ThreadCount,UserModeTime,WriteOperationCount";
            // 取進程信息
            long[] c0 = readCpu(Runtime.getRuntime().exec(procCmd));
            Thread.sleep(CPUTIME);
            long[] c1 = readCpu(Runtime.getRuntime().exec(procCmd));
            if (c0 != null && c1 != null) {
                long idletime = c1[0] - c0[0];
                long busytime = c1[1] - c0[1];
                return Double.valueOf(
                        PERCENT * (busytime) / (busytime + idletime))
                        .doubleValue();
            } else {
                return 0.0;
            }
        } catch (Exception ex) {
            ex.printStackTrace();
            return 0.0;
        }
    }

    /** *//**
     * 讀取CPU信息.
     * @param proc
     * @return
     * @author amg     * Creation date: 2008-4-25 - 下午06:10:14
     */
    private long[] readCpu(final Process proc) {
        long[] retn = new long[2];
        try {
            proc.getOutputStream().close();
            InputStreamReader ir = new InputStreamReader(proc.getInputStream());
            LineNumberReader input = new LineNumberReader(ir);
            String line = input.readLine();
            if (line == null || line.length() < FAULTLENGTH) {
                return null;
            }
            int capidx = line.indexOf("Caption");
            int cmdidx = line.indexOf("CommandLine");
            int rocidx = line.indexOf("ReadOperationCount");
            int umtidx = line.indexOf("UserModeTime");
            int kmtidx = line.indexOf("KernelModeTime");
            int wocidx = line.indexOf("WriteOperationCount");
            long idletime = 0;
            long kneltime = 0;
            long usertime = 0;
            while ((line = input.readLine()) != null) {
                if (line.length() < wocidx) {
                    continue;
                }
                // 字段出現順序:Caption,CommandLine,KernelModeTime,ReadOperationCount,
                // ThreadCount,UserModeTime,WriteOperation
                String caption = Bytes.substring(line, capidx, cmdidx - 1)
                        .trim();
                String cmd = Bytes.substring(line, cmdidx, kmtidx - 1).trim();
                if (cmd.indexOf("wmic.exe") >= 0) {
                    continue;
                }
                // log.info("line="+line);
                if (caption.equals("System Idle Process")
                        || caption.equals("System")) {
                    idletime += Long.valueOf(
                            Bytes.substring(line, kmtidx, rocidx - 1).trim())
                            .longValue();
                    idletime += Long.valueOf(
                            Bytes.substring(line, umtidx, wocidx - 1).trim())
                            .longValue();
                    continue;
                }

                kneltime += Long.valueOf(
                        Bytes.substring(line, kmtidx, rocidx - 1).trim())
                        .longValue();
                usertime += Long.valueOf(
                        Bytes.substring(line, umtidx, wocidx - 1).trim())
                        .longValue();
            }
            retn[0] = idletime;
            retn[1] = kneltime + usertime;
            return retn;
        } catch (Exception ex) {
            ex.printStackTrace();
        } finally {
            try {
                proc.getInputStream().close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        return null;
    }
   
    /** *//**
     * 測試方法.
     * @param args
     * @throws Exception
     * @author amg     * Creation date: 2008-4-30 - 下午04:47:29
     */
    public static void main(String[] args) throws Exception {
        IMonitorService service = new MonitorServiceImpl();
        MonitorInfoBean monitorInfo = service.getMonitorInfoBean();
        System.out.println("cpu占有率=" + monitorInfo.getCpuRatio());
       
        System.out.println("可使用內存=" + monitorInfo.getTotalMemory());
        System.out.println("剩余內存=" + monitorInfo.getFreeMemory());
        System.out.println("最大可使用內存=" + monitorInfo.getMaxMemory());
       
        System.out.println("操作系統=" + monitorInfo.getOsName());
        System.out.println("總的物理內存=" + monitorInfo.getTotalMemorySize() + "kb");
        System.out.println("剩余的物理內存=" + monitorInfo.getFreeMemory() + "kb");
        System.out.println("已使用的物理內存=" + monitorInfo.getUsedMemory() + "kb");
        System.out.println("線程總數=" + monitorInfo.getTotalThread() + "kb");
    }
}
該實現類中需要用到一個自己編寫byte的工具類,該類的代碼如下所示:

Java代碼 
package  com.amgkaka.performance;  
  
/** */ /**  
 * byte操作類.  
 * @author amg * @version 1.0   
 * Creation date: 2008-4-30 - 下午04:57:23  
 */   
public   class  Bytes {  
    /** */ /**  
     * 由于String.subString對漢字處理存在問題(把一個漢字視為一個字節),因此在  
     * 包含漢字的字符串時存在隱患,現調整如下:  
     * @param src 要截取的字符串  
     * @param start_idx 開始坐標(包括該坐標)  
     * @param end_idx   截止坐標(包括該坐標)  
     * @return  
     */   
    public   static  String substring(String src,  int  start_idx,  int  end_idx){  
        byte [] b = src.getBytes();  
        String tgt = "" ;  
        for ( int  i=start_idx; i<=end_idx; i++){  
            tgt +=(char )b[i];  
        }  
        return  tgt;  
    }  
}  
package com.amgkaka.performance;

/** *//**
 * byte操作類.
 * @author amg * @version 1.0
 * Creation date: 2008-4-30 - 下午04:57:23
 */
public class Bytes {
    /** *//**
     * 由于String.subString對漢字處理存在問題(把一個漢字視為一個字節),因此在
     * 包含漢字的字符串時存在隱患,現調整如下:
     * @param src 要截取的字符串
     * @param start_idx 開始坐標(包括該坐標)
     * @param end_idx   截止坐標(包括該坐標)
     * @return
     */
    public static String substring(String src, int start_idx, int end_idx){
        byte[] b = src.getBytes();
        String tgt = "";
        for(int i=start_idx; i<=end_idx; i++){
            tgt +=(char)b[i];
        }
        return tgt;
    }
}
運行下MonitorBeanImpl類,讀者將會看到當前的內存、cpu利用率等信息。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久久久久久亚洲| 亚洲成人激情图| 久久久噜噜噜久噜久久| 国产精品欧美日韩一区二区| 亚洲精品成人免费| 国产欧美日韩精品专区| 精品国产老师黑色丝袜高跟鞋| 亚洲欧美一区二区三区情侣bbw| 66m—66摸成人免费视频| 91欧美激情另类亚洲| 国产欧美精品日韩| 青青草成人在线| 2019中文字幕免费视频| 亚洲理论在线a中文字幕| 深夜精品寂寞黄网站在线观看| 欧美亚洲第一区| 69av视频在线播放| 国产精品久久久精品| 日韩美女在线看| 91久久国产综合久久91精品网站| 亚洲精品久久久久久下一站| 欧美丝袜一区二区三区| 亚洲最大在线视频| 国产亚洲欧美一区| 精品国产乱码久久久久酒店| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美裸体男粗大视频在线观看| 国产免费一区视频观看免费| 亚洲精品成人av| 2019中文在线观看| 在线播放国产一区中文字幕剧情欧美| 国内精品久久久久久影视8| 丝袜亚洲另类欧美重口| 美女久久久久久久久久久| 亚洲激情在线观看视频免费| 国产精品久久久久久久久久新婚| 三级精品视频久久久久| 孩xxxx性bbbb欧美| 国产精品都在这里| 国产精品久久久久久久久借妻| 九九热这里只有精品6| 国产精品久久久久久久久粉嫩av| 色yeye香蕉凹凸一区二区av| 456国产精品| 亚洲网站在线观看| 亚洲欧美制服另类日韩| 深夜福利国产精品| 日韩一区二区av| 亚洲石原莉奈一区二区在线观看| 久久精品在线视频| www.久久色.com| 欧美视频在线观看 亚洲欧| 久久精品这里热有精品| 在线看日韩欧美| 欧美最猛性xxxxx免费| 97国产真实伦对白精彩视频8| 色爱精品视频一区| 色老头一区二区三区| 亚洲精品福利免费在线观看| 亚洲美女av电影| 欧美大片欧美激情性色a∨久久| 日韩69视频在线观看| 日韩中文字幕视频| 亚洲免费成人av电影| 7m第一福利500精品视频| 亚洲美女中文字幕| 57pao成人永久免费视频| 亚洲娇小xxxx欧美娇小| 国产精品专区h在线观看| 亚洲欧美另类国产| 亚洲国产精品久久| 日韩精品高清视频| 26uuu另类亚洲欧美日本老年| 亚洲女人天堂色在线7777| 国产精品h片在线播放| 人人澡人人澡人人看欧美| 欧美极品少妇xxxxⅹ免费视频| 欧洲美女7788成人免费视频| 亚洲一区二区三区乱码aⅴ| 欧美激情在线播放| 国产精品久久色| www.亚洲人.com| 亚洲精品在线看| 日韩高清电影好看的电视剧电影| 91精品国产一区| 亚洲视频视频在线| 国产精品欧美风情| 国产精品久久久一区| 国自产精品手机在线观看视频| 亚洲欧美国产va在线影院| 欧美美女15p| 中日韩美女免费视频网址在线观看| 久久久久久久久久国产精品| 九九热这里只有在线精品视| 91av在线网站| 亚洲乱码国产乱码精品精| 欧美性一区二区三区| 日韩精品小视频| 亚洲色图欧美制服丝袜另类第一页| 亚洲а∨天堂久久精品9966| 欧美一级高清免费播放| 国产精品视频内| 97成人在线视频| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲欧美精品伊人久久| 91极品女神在线| 久久精品久久精品亚洲人| 91精品久久久久久久久久| 亚洲男人天堂视频| 国产精品久久久久久婷婷天堂| 不卡av在线播放| 亚洲视频免费一区| 亚洲国产婷婷香蕉久久久久久| 亚洲四色影视在线观看| 欧美日韩中文字幕在线| 久久久久久久久久久免费精品| 欧美在线日韩在线| 96pao国产成视频永久免费| 欧美俄罗斯乱妇| 中文亚洲视频在线| 日韩在线视频观看正片免费网站| 亚洲高清av在线| 日韩中文视频免费在线观看| 国产自摸综合网| 九九热最新视频//这里只有精品| 亚洲国产小视频| 一区二区三区www| 日韩精品免费在线播放| 欧美黄色小视频| 日韩av影片在线观看| 久久国产精品影片| 久久欧美在线电影| 亚洲成av人乱码色午夜| 精品视频在线播放| 欧美成人第一页| 国产精品亚洲аv天堂网| 国产精品69久久久久| 日韩日本欧美亚洲| 亚洲国内精品视频| 北条麻妃一区二区在线观看| 久久精品男人天堂| 国产精品久久久久久久久久久久久| 欧美老女人性视频| 日韩美女av在线免费观看| 色久欧美在线视频观看| 欧美激情2020午夜免费观看| 成人午夜高潮视频| 亚洲精品一区二区在线| 91久久久久久久久久| 欧美激情视频网址| 日韩美女免费线视频| 高跟丝袜一区二区三区| 亚洲视频在线观看| 国产成人精品综合| 国产精品自拍网| 日韩激情视频在线播放| 久久这里有精品视频| 国产美女91呻吟求| 久久久亚洲国产天美传媒修理工| 欧美性感美女h网站在线观看免费| 亚洲精品久久久久久下一站| 亚洲成年人在线播放| 欧美日韩aaaa| 亚洲九九九在线观看|