`
jeelee
  • 浏览: 637607 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Java获取系统信息(cpu,内存,硬盘,进程等)的相关方法

    博客分类:
  • java
阅读更多
1.利用jdk自带的API获取信息:(只支持jdk1.60以上的版本啊)

import java.io.InputStreamReader;
import java.io.LineNumberReader;
import java.util.ArrayList;
import java.util.List;

import mytools.com.sun.management.OperatingSystemMXBean;
import mytools.java.io.File;
import mytools.java.lang.management.ManagementFactory;
/**
* 获取windows系统信息(CPU,内存,文件系统)
* @author libing
*
*/

public class WindowsInfoUtil {
    private static final int CPUTIME = 500;
    private static final int PERCENT = 100;
    private static final int FAULTLENGTH = 10;

    public static void main(String[] args) {
    System.out.println(getCpuRatioForWindows());
    System.out.println(getMemery());
    System.out.println(getDisk());
}

//获取内存使用率
public static String getMemery(){
  OperatingSystemMXBean osmxb = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();
  // 总的物理内存+虚拟内存
  long totalvirtualMemory = osmxb.getTotalSwapSpaceSize();
  // 剩余的物理内存
  long freePhysicalMemorySize = osmxb.getFreePhysicalMemorySize();
  Double compare=(Double)(1-freePhysicalMemorySize*1.0/totalvirtualMemory)*100;
  String str="内存已使用:"+compare.intValue()+"%";
  return str;
}

//获取文件系统使用率
public static List<String> getDisk() {
  // 操作系统
  List<String> list=new ArrayList<String>();
  for (char c = 'A'; c <= 'Z'; c++) {
   String dirName = c + ":/";
   File win = new File(dirName);
         if(win.exists()){
          long total=(long)win.getTotalSpace();
          long free=(long)win.getFreeSpace();
          Double compare=(Double)(1-free*1.0/total)*100;
          String str=c+":盘  已使用 "+compare.intValue()+"%";
          list.add(str);
         }
     }
        return list;
}

//获得cpu使用率
public static String 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 "CPU使用率:"+Double.valueOf(PERCENT * (busytime)*1.0 / (busytime + idletime)).intValue()+"%";
             } else {
                 return "CPU使用率:"+0+"%";
             }
         } catch (Exception ex) {
             ex.printStackTrace();
             return "CPU使用率:"+0+"%";
         }
     }

//读取cpu相关信息
    private static 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 =substring(line, capidx, cmdidx - 1).trim();
                String cmd = substring(line, cmdidx, kmtidx - 1).trim();
                if (cmd.indexOf("wmic.exe") >= 0) {
                    continue;
                }
                String s1 = substring(line, kmtidx, rocidx - 1).trim();
                String s2 = substring(line, umtidx, wocidx - 1).trim();
                if (caption.equals("System Idle Process") || caption.equals("System")) {
                    if (s1.length() > 0)
                        idletime += Long.valueOf(s1).longValue();
                    if (s2.length() > 0)
                        idletime += Long.valueOf(s2).longValue();
                    continue;
                }
                if (s1.length() > 0)
                    kneltime += Long.valueOf(s1).longValue();
                if (s2.length() > 0)
                    usertime += Long.valueOf(s2).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;
    }

    /**
   * 由于String.subString对汉字处理存在问题(把一个汉字视为一个字节),因此在 包含汉字的字符串时存在隐患,现调整如下:
   * @param src 要截取的字符串
   * @param start_idx 开始坐标(包括该坐标)
   * @param end_idx 截止坐标(包括该坐标)
   * @return
   */
    private 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;
  }
}

2.利用第三方的jar包:(Hyperic-hq官方网站:http://www.hyperic.com)

通过Hyperic-hq产品的基础包sigar.jar来实现服务器状态数据的获取。Sigar.jar包是通过本地方法来调用操作系统API来获取系统相关数据。Windows操作系统下Sigar.jar依赖sigar-amd64-winnt.dll或sigar-x86-winnt.dll,linux 操作系统下则依赖libsigar-amd64-linux.so或libsigar-x86-linux.so

import java.net.InetAddress;
import java.net.UnknownHostException;
import org.hyperic.sigar.CpuInfo;
import org.hyperic.sigar.CpuPerc;
import org.hyperic.sigar.FileSystem;
import org.hyperic.sigar.FileSystemUsage;
import org.hyperic.sigar.Mem;
import org.hyperic.sigar.NetFlags;
import org.hyperic.sigar.NetInterfaceConfig;
import org.hyperic.sigar.NetInterfaceStat;
import org.hyperic.sigar.OperatingSystem;
import org.hyperic.sigar.Sigar;
import org.hyperic.sigar.SigarException;
import org.hyperic.sigar.SigarNotImplementedException;
import org.hyperic.sigar.Swap;

public class SysInfo {

// 1.CPU资源信息

// a)CPU数量(单位:个)
public static int getCpuCount() throws SigarException {
  Sigar sigar = new Sigar();
  try {
   return sigar.getCpuInfoList().length;
  } finally {
   sigar.close();
  }
}

// b)CPU的总量(单位:HZ)及CPU的相关信息
public void getCpuTotal() {
  Sigar sigar = new Sigar();
  CpuInfo[] infos;
  try {
   infos = sigar.getCpuInfoList();
   for (int i = 0; i < infos.length; i++) {// 不管是单块CPU还是多CPU都适用
    CpuInfo info = infos[i];
    System.out.println("mhz=" + info.getMhz());// CPU的总量MHz
    System.out.println("vendor=" + info.getVendor());// 获得CPU的卖主,如:Intel
    System.out.println("model=" + info.getModel());// 获得CPU的类别,如:Celeron
    System.out.println("cache size=" + info.getCacheSize());// 缓冲存储器数量
   }
  } catch (SigarException e) {
   e.printStackTrace();
  }
}

// c)CPU的用户使用量、系统使用剩余量、总的剩余量、总的使用占用量等(单位:100%)
public void testCpuPerc() {
  Sigar sigar = new Sigar();
  // 方式一,主要是针对一块CPU的情况
  CpuPerc cpu;
  try {
   cpu = sigar.getCpuPerc();
   printCpuPerc(cpu);
  } catch (SigarException e) {
   e.printStackTrace();
  }
  // 方式二,不管是单块CPU还是多CPU都适用
  CpuPerc cpuList[] = null;
  try {
   cpuList = sigar.getCpuPercList();
  } catch (SigarException e) {
   e.printStackTrace();
   return;
  }
  for (int i = 0; i < cpuList.length; i++) {
   printCpuPerc(cpuList[i]);
  }
}

private void printCpuPerc(CpuPerc cpu) {
  System.out.println("User :" + CpuPerc.format(cpu.getUser()));// 用户使用率
  System.out.println("Sys :" + CpuPerc.format(cpu.getSys()));// 系统使用率
  System.out.println("Wait :" + CpuPerc.format(cpu.getWait()));// 当前等待率
  System.out.println("Nice :" + CpuPerc.format(cpu.getNice()));//
  System.out.println("Idle :" + CpuPerc.format(cpu.getIdle()));// 当前空闲率
  System.out.println("Total :" + CpuPerc.format(cpu.getCombined()));// 总的使用率
}

// 2.内存资源信息
public void getPhysicalMemory() {
  // a)物理内存信息
  Sigar sigar = new Sigar();
  Mem mem;
  try {
   mem = sigar.getMem();
   // 内存总量
   System.out.println("Total = " + mem.getTotal() / 1024L + "K av");
   // 当前内存使用量
   System.out.println("Used = " + mem.getUsed() / 1024L + "K used");
   // 当前内存剩余量
   System.out.println("Free = " + mem.getFree() / 1024L + "K free");

   // b)系统页面文件交换区信息
   Swap swap = sigar.getSwap();
   // 交换区总量
   System.out.println("Total = " + swap.getTotal() / 1024L + "K av");
   // 当前交换区使用量
   System.out.println("Used = " + swap.getUsed() / 1024L + "K used");
   // 当前交换区剩余量
   System.out.println("Free = " + swap.getFree() / 1024L + "K free");
  } catch (SigarException e) {
   e.printStackTrace();
  }
}

// 3.操作系统信息

// a)取到当前操作系统的名称:
public String getPlatformName() {
  String hostname = "";
  try {
   hostname = InetAddress.getLocalHost().getHostName();
  } catch (Exception exc) {
   Sigar sigar = new Sigar();
   try {
    hostname = sigar.getNetInfo().getHostName();
   } catch (SigarException e) {
    hostname = "localhost.unknown";
   } finally {
    sigar.close();
   }
  }
  return hostname;
}

// b)取当前操作系统的信息
public void testGetOSInfo() {
  OperatingSystem OS = OperatingSystem.getInstance();
  // 操作系统内核类型如: 386、486、586等x86
  System.out.println("OS.getArch() = " + OS.getArch());
  System.out.println("OS.getCpuEndian() = " + OS.getCpuEndian());//
  System.out.println("OS.getDataModel() = " + OS.getDataModel());//
  // 系统描述
  System.out.println("OS.getDescription() = " + OS.getDescription());
  System.out.println("OS.getMachine() = " + OS.getMachine());//
  // 操作系统类型
  System.out.println("OS.getName() = " + OS.getName());
  System.out.println("OS.getPatchLevel() = " + OS.getPatchLevel());//
  // 操作系统的卖主
  System.out.println("OS.getVendor() = " + OS.getVendor());
  // 卖主名称
  System.out
    .println("OS.getVendorCodeName() = " + OS.getVendorCodeName());
  // 操作系统名称
  System.out.println("OS.getVendorName() = " + OS.getVendorName());
  // 操作系统卖主类型
  System.out.println("OS.getVendorVersion() = " + OS.getVendorVersion());
  // 操作系统的版本号
  System.out.println("OS.getVersion() = " + OS.getVersion());
}

// c)取当前系统进程表中的用户信息
public void testWho() {
  try {
   Sigar sigar = new Sigar();
   org.hyperic.sigar.Who[] who = sigar.getWhoList();
   if (who != null && who.length > 0) {
    for (int i = 0; i < who.length; i++) {
     System.out.println("\n~~~~~~~~~" + String.valueOf(i)+ "~~~~~~~~~");
     org.hyperic.sigar.Who _who = who[i];
     System.out.println("getDevice() = " + _who.getDevice());
     System.out.println("getHost() = " + _who.getHost());
     System.out.println("getTime() = " + _who.getTime());
     // 当前系统进程表中的用户名
     System.out.println("getUser() = " + _who.getUser());
    }
   }
  } catch (SigarException e) {
   e.printStackTrace();
  }
}

// 4.资源信息(主要是硬盘)

// a)取硬盘已有的分区及其详细信息(通过sigar.getFileSystemList()来获得FileSystem列表对象,然后对其进行编历):
public void testFileSystemInfo() throws Exception {
  Sigar sigar = new Sigar();
  FileSystem fslist[] = sigar.getFileSystemList();
  //String dir = System.getProperty("user.home");// 当前用户文件夹路径
  for (int i = 0; i < fslist.length; i++) {
   System.out.println("\n~~~~~~~~~~" + i + "~~~~~~~~~~");
   FileSystem fs = fslist[i];
   // 分区的盘符名称
   System.out.println("fs.getDevName() = " + fs.getDevName());
   // 分区的盘符名称
   System.out.println("fs.getDirName() = " + fs.getDirName());
   System.out.println("fs.getFlags() = " + fs.getFlags());//
   // 文件系统类型,比如 FAT32、NTFS
   System.out.println("fs.getSysTypeName() = " + fs.getSysTypeName());
   // 文件系统类型名,比如本地硬盘、光驱、网络文件系统等
   System.out.println("fs.getTypeName() = " + fs.getTypeName());
   // 文件系统类型
   System.out.println("fs.getType() = " + fs.getType());
   FileSystemUsage usage = null;
   try {
    usage = sigar.getFileSystemUsage(fs.getDirName());
   } catch (SigarException e) {
    if (fs.getType() == 2)
     throw e;
    continue;
   }
   switch (fs.getType()) {
   case 0: // TYPE_UNKNOWN :未知
    break;
   case 1: // TYPE_NONE
    break;
   case 2: // TYPE_LOCAL_DISK : 本地硬盘
    // 文件系统总大小
    System.out.println(" Total = " + usage.getTotal() + "KB");
    // 文件系统剩余大小
    System.out.println(" Free = " + usage.getFree() + "KB");
    // 文件系统可用大小
    System.out.println(" Avail = " + usage.getAvail() + "KB");
    // 文件系统已经使用量
    System.out.println(" Used = " + usage.getUsed() + "KB");
    double usePercent = usage.getUsePercent() * 100D;
    // 文件系统资源的利用率
    System.out.println(" Usage = " + usePercent + "%");
    break;
   case 3:// TYPE_NETWORK :网络
    break;
   case 4:// TYPE_RAM_DISK :闪存
    break;
   case 5:// TYPE_CDROM :光驱
    break;
   case 6:// TYPE_SWAP :页面交换
    break;
   }
   System.out.println(" DiskReads = " + usage.getDiskReads());
   System.out.println(" DiskWrites = " + usage.getDiskWrites());
  }
  return;
}

// 5.网络信息

// a)当前机器的正式域名
public String getFQDN() {
  Sigar sigar = null;
  try {
   return InetAddress.getLocalHost().getCanonicalHostName();
  } catch (UnknownHostException e) {
   try {
    sigar = new Sigar();
    return sigar.getFQDN();
   } catch (SigarException ex) {
    return null;
   } finally {
    sigar.close();
   }
  }
}

// b)取到当前机器的IP地址
public String getDefaultIpAddress() {
  String address = null;
  try {
   address = InetAddress.getLocalHost().getHostAddress();
   // 没有出现异常而正常当取到的IP时,如果取到的不是网卡循回地址时就返回
   // 否则再通过Sigar工具包中的方法来获取
   if (!NetFlags.LOOPBACK_ADDRESS.equals(address)) {
    return address;
   }
  } catch (UnknownHostException e) {
   // hostname not in DNS or /etc/hosts
  }
  Sigar sigar = new Sigar();
  try {
   address = sigar.getNetInterfaceConfig().getAddress();
  } catch (SigarException e) {
   address = NetFlags.LOOPBACK_ADDRESS;
  } finally {
   sigar.close();
  }
  return address;
}

// c)取到当前机器的MAC地址
public String getMAC() {
  Sigar sigar = null;
  try {
   sigar = new Sigar();
   String[] ifaces = sigar.getNetInterfaceList();
   String hwaddr = null;
   for (int i = 0; i < ifaces.length; i++) {
    NetInterfaceConfig cfg = sigar.getNetInterfaceConfig(ifaces[i]);
    if (NetFlags.LOOPBACK_ADDRESS.equals(cfg.getAddress())
      || (cfg.getFlags() & NetFlags.IFF_LOOPBACK) != 0
      || NetFlags.NULL_HWADDR.equals(cfg.getHwaddr())) {
     continue;
    }
    /*
     * 如果存在多张网卡包括虚拟机的网卡,默认只取第一张网卡的MAC地址,如果要返回所有的网卡(包括物理的和虚拟的)则可以修改方法的返回类型为数组或Collection
     * ,通过在for循环里取到的多个MAC地址。
     */
    hwaddr = cfg.getHwaddr();
    break;
   }
   return hwaddr != null ? hwaddr : null;
  } catch (Exception e) {
   return null;
  } finally {
   if (sigar != null)
    sigar.close();
  }
}

// d)获取网络流量等信息
public void testNetIfList() throws Exception {
  Sigar sigar = new Sigar();
  String ifNames[] = sigar.getNetInterfaceList();
  for (int i = 0; i < ifNames.length; i++) {
   String name = ifNames[i];
   NetInterfaceConfig ifconfig = sigar.getNetInterfaceConfig(name);
   print("\nname = " + name);// 网络设备名
   print("Address = " + ifconfig.getAddress());// IP地址
   print("Netmask = " + ifconfig.getNetmask());// 子网掩码
   if ((ifconfig.getFlags() & 1L) <= 0L) {
    print("!IFF_UP...skipping getNetInterfaceStat");
    continue;
   }
   try {
    NetInterfaceStat ifstat = sigar.getNetInterfaceStat(name);
    print("RxPackets = " + ifstat.getRxPackets());// 接收的总包裹数
    print("TxPackets = " + ifstat.getTxPackets());// 发送的总包裹数
    print("RxBytes = " + ifstat.getRxBytes());// 接收到的总字节数
    print("TxBytes = " + ifstat.getTxBytes());// 发送的总字节数
    print("RxErrors = " + ifstat.getRxErrors());// 接收到的错误包数
    print("TxErrors = " + ifstat.getTxErrors());// 发送数据包时的错误数
    print("RxDropped = " + ifstat.getRxDropped());// 接收时丢弃的包数
    print("TxDropped = " + ifstat.getTxDropped());// 发送时丢弃的包数
   } catch (SigarNotImplementedException e) {
   } catch (SigarException e) {
    print(e.getMessage());
   }
  }
}

void print(String msg) {
  System.out.println(msg);
}

// e)一些其他的信息
public void getEthernetInfo() {
  Sigar sigar = null;
  try {
   sigar = new Sigar();
   String[] ifaces = sigar.getNetInterfaceList();
   for (int i = 0; i < ifaces.length; i++) {
    NetInterfaceConfig cfg = sigar.getNetInterfaceConfig(ifaces[i]);
    if (NetFlags.LOOPBACK_ADDRESS.equals(cfg.getAddress())
      || (cfg.getFlags() & NetFlags.IFF_LOOPBACK) != 0
      || NetFlags.NULL_HWADDR.equals(cfg.getHwaddr())) {
     continue;
    }
    System.out.println("cfg.getAddress() = " + cfg.getAddress());// IP地址
    System.out
      .println("cfg.getBroadcast() = " + cfg.getBroadcast());// 网关广播地址
    System.out.println("cfg.getHwaddr() = " + cfg.getHwaddr());// 网卡MAC地址
    System.out.println("cfg.getNetmask() = " + cfg.getNetmask());// 子网掩码
    System.out.println("cfg.getDescription() = "
      + cfg.getDescription());// 网卡描述信息
    System.out.println("cfg.getType() = " + cfg.getType());//
    System.out.println("cfg.getDestination() = "
      + cfg.getDestination());
    System.out.println("cfg.getFlags() = " + cfg.getFlags());//
    System.out.println("cfg.getMetric() = " + cfg.getMetric());
    System.out.println("cfg.getMtu() = " + cfg.getMtu());
    System.out.println("cfg.getName() = " + cfg.getName());
    System.out.println();
   }
  } catch (Exception e) {
   System.out.println("Error while creating GUID" + e);
  } finally {
   if (sigar != null)
    sigar.close();
  }
}

}



分享到:
评论
9 楼 justlogin 2015-03-05  
TonyLian 写道
一般来说获取机器硬件信息基本都是用来生成“机器码”,用来和“注册码”一起起到注册认证功能的。

但如果使用JNI的方式,怎么能够避免使用者因为发现了 .dll和.so 文件而“一目了然”是JNI,然后很容易找到反编译后的调用JNI的接口(即使类名上使用欺骗命名等手段)。

接下来用接口自己做一个JNI的dll/so,所有都返回空白或已知注册码的那台机器的固定硬件信息?

不知道LZ对这方面是否有考虑呢?

有没有什么办法阻止获取?
8 楼 TonyLian 2015-02-09  
一般来说获取机器硬件信息基本都是用来生成“机器码”,用来和“注册码”一起起到注册认证功能的。

但如果使用JNI的方式,怎么能够避免使用者因为发现了 .dll和.so 文件而“一目了然”是JNI,然后很容易找到反编译后的调用JNI的接口(即使类名上使用欺骗命名等手段)。

接下来用接口自己做一个JNI的dll/so,所有都返回空白或已知注册码的那台机器的固定硬件信息?

不知道LZ对这方面是否有考虑呢?
7 楼 stuxnet 2013-02-20  
非常感谢楼主,太棒了,岂是一顶所能抒怀的。
6 楼 zhenjw 2012-12-18  
灰常感谢楼主
5 楼 lansor2009 2012-05-10  
非常非常感谢楼主!!!!
4 楼 lenka_xiu 2011-09-05  
真不错的文章,可是我不知道怎么弄。能加QQ教教我不?我的QQ1009610689
3 楼 cnm-111 2011-08-09  
楼主你好,能解释下,如果是机子的cpu是双核的话,cpu的各种统计信息,如总的使用率怎么计算呢?是每一个cpu的值接相加吗?
还有就是那个流量统计的信息代表什么含义? 求解@。。
2 楼 dllk08 2011-04-06  
对这篇文章的赞许不是一言两语啊,找了那么久得解决办法,终于在这里找到答案了。嘿嘿!高兴!谢谢!
1 楼 boshding 2010-11-01  
太棒了,岂是一顶所能抒怀的。

相关推荐

    Java获取系统信息(cpu,内存,硬盘,进程等)的相关方法.pdf

    Java 获取系统信息(CPU、内存、硬盘、进程等)的相关方法 Java 获取系统信息是指通过 Java 语言获取当前系统的各种信息,包括 CPU、内存、硬盘、进程等。下面将介绍两种获取系统信息的方法。 方法一:使用 Java ...

    Java获取系统信息(cpu_内存_硬盘_进程等)的相关方法

    Java 获取系统信息(CPU、内存、硬盘、进程等)的相关方法 Java 获取系统信息是指通过 Java 语言获取当前系统的各种信息,包括 CPU 信息、内存信息、硬盘信息、进程信息等。在实际开发中,这些信息往往是非常有用的...

    java管理windows系统内存_java释放内存缓存_java获得CPU使用率_系统内存_硬盘_进程源代码

    "java管理windows系统内存_java释放内存缓存_java获得CPU使用率_系统内存_硬盘_进程源代码" 在Windows操作系统中,内存管理是一个非常重要的方面。Windows实现按需调页的虚拟内存机制,使得应用程序可以使用超过...

    Java获取系统信息

    Java 获取系统信息是指通过 Java 语言来获取系统的各种信息,包括 CPU 信息、内存信息、硬盘信息、进程信息等。在 Java 中,我们可以使用多种方式来获取系统信息,如使用 Runtime 类、System 类、ManagementFactory ...

    获取系统信息(cpu,内存,硬盘等。。。)的第三方jar包(sigar.jar)

    这个第三方jar包`sigar.jar`提供了丰富的API,允许开发者便捷地获取各种操作系统级别的信息,包括CPU、内存、硬盘、网络等资源的状态。在Java应用程序中,通过导入`sigar.jar`,我们可以轻松实现对运行环境的系统...

    Android获取cpu,内存,磁盘使用率信息

    获取系统级信息,如CPU和内存使用率,通常需要`android.permission.SYSTEM_ALERT_WINDOW`(显示系统级窗口)或`android.permission.ACCESS_FINE_LOCATION`(访问位置信息)等权限,而这些权限属于危险权限,需要用户...

    基于java通过第三方jar包sigar的支持,完成对服务器系统的参数监控,包括CPU、内存、硬盘以及网络流量的实时监控.zip

    本项目就是基于Java利用第三方jar包Sigar(System Information Gatherer and Reporter)来实现服务器系统的实时参数监控,涵盖了CPU、内存、硬盘以及网络流量四大关键指标。 首先,让我们深入理解Sigar库。Sigar是...

    MooInfo是OSHI 的一种可视化实现,用于查看有关系统和硬件的信息 如操作系统,进程,内存,CPU,磁盘,设备,传感器等

    2. **进程信息**:展示正在运行的进程列表,包括进程ID、名称、状态、CPU和内存使用情况等,这对于系统性能分析和故障排查很有帮助。 3. **内存状态**:提供总内存、已用内存、空闲内存等数据,以及内存分配和使用率...

    Android的cpu硬盘内存网络设置系统信息硬件信息.pdf

    本文主要围绕Android设备的CPU、硬盘、内存以及网络设置等信息的获取进行探讨。 首先,查看手机信息的可行性分析涉及到对系统接口的理解和使用。在Android系统中,大部分硬件和系统信息可以通过Java API或者系统...

    java(jni)获得CPU、内存使用率 绝对可用

    在Java编程环境中,有时我们需要获取系统的资源使用情况,如CPU和内存的利用率。为了实现这一目标,我们可以利用JNI(Java Native Interface),它提供了一种方式让Java代码能够调用C/C++编写的本地方法,从而获取...

    Linux服务器监测命令及CPU、硬盘、内存状态命令

    首先,/proc文件系统是Linux内核提供的一个接口,它以文件的形式存在于内存中,通过这个接口,系统管理员可以访问到内核内部的数据结构,并获取系统及进程的实时信息,包括CPU、硬盘、内存等硬件的状态。/proc文件...

    获取cpu使用率和内存使用情况

    通过阅读和理解这个文件,我们可以学习如何直接从操作系统获取内存使用情况。 综上所述,掌握获取和分析CPU使用率及内存使用情况的技能对IT专业人员至关重要,无论是为了优化代码、监控系统健康还是解决问题。通过...

    java实现的系统进程调度实验

    这个实验旨在通过Java语言来模拟实际操作系统中的系统进程调度过程,同时在实验二中加入了内存分配的模拟,以帮助学习者更深入地理解这些概念。 首先,我们来看"进程调度"。在操作系统中,进程调度是决定哪个进程在...

    涉及进程和内存等的工具和说明文档

    在Linux系统中,`ps`命令可以列出当前系统中的所有进程,而`top`或`htop`提供实时的进程监控,包括CPU使用率、内存占用等信息。 内存管理是操作系统的核心功能之一,主要分为物理内存和虚拟内存。物理内存是指...

    查看CUP、内存、硬盘使用情况

    Sigar 是一个跨平台的系统监控库,由Hypertable项目开发,提供了一种统一的方式来获取各种操作系统的信息,包括CPU、内存、硬盘使用率等。在Windows系统下,使用Sigar时,我们需要确保对应的动态链接库文件(如`lib...

    检测CPU、内存、网速、线程的工具

    对于开发者,`DotnetSysmon`是一个针对.NET环境的系统监视工具,它可以提供详细的CPU使用信息,包括进程、线程等的CPU利用率。 内存,或称RAM(随机存取存储器),是计算机运行过程中临时存储数据的地方。内存不足...

Global site tag (gtag.js) - Google Analytics