jconsole中自带了进程的cpu使用率,阅读源码后,我移植到线程上了。java
如下jconsole是进程cpu计算的代码算法
float cpuUsage = Math.min(99F,elapsedCpu / (elapsedTime * 10000F * result.nCPUs));
elapsedCpu是一段时间进程占用cpu的时间jvm
elapsedTime是Java 虚拟机的正常运行时间只差spa
nCPUs是jvm可用的cpu数量线程
进程cpu的利用率=进程时间差/(jvm运行时间差)*可用的cpu数量code
线程的cpu时间ThreadMXBean的getThreadCpuTime进程
jvm运行时间RuntimeMXBean的getUptimeget
jvm可用的核心数OperatingSystemMXBean的getAvailableProcessors源码
一切都ok了,这个算法虽然感受怪怪的,可是结果靠得住,想一想jvm假如可以合理利用cpu,那么这个算法是能等同于各个cpu运行时间之和。
虚拟机