如果你有用过Oshi在Windows8以上操作系统运行过获取CPU使用率的程序,你可能会发现一个问题:获取到的CPU使用率与Windows任务管理器显示的CPU使用率不匹配。
下面贴出使用hutool-system获取CPU使用率的代码(hutool-system是对oshi的封装,本质上还是oshi获取cpu使用率)以及运行现象
public static void getCPUInfo(){
CpuInfo cpuInfo = OshiUtil.getCpuInfo();
double free = cpuInfo.getFree();
DecimalFormat format = new DecimalFormat("#.00");
System.out.println("cpu利用率:" + Double.parseDouble(format.format(100.0D - free)));
}
可以看到,当调用上述函数时,运行时给出的CPU利用率和任务管理器显示的基本不一致(可以自行调用多次尝试一下)。于是我就去翻了Oshi的issues,发现有人提出过这个问题,并且已经收到了Lead delveloper of Oshi "dbwiddis"的回答,让我们一起来看看吧
翻译一下,大致意思就是
Windows 任务管理器测量‘已完成的工作’而不是‘CPU 使用率’
如果想要Oshi返回的值和Windows任务管理器显示的值一致,则应该修改Oshi配置或者在Central Processor类实例化之前调用
GlobalConfig.set(GlobalConfig.OSHI_OS_WINDOWS_CPU_UTILITY, true);
看完之后我就在上述函数中OshiUtil.getCpuInfo();之前加了上面那一行代码,经过测试,果然输出的值跟任务管理器大差不差了!此处就不放贴图了,作者比较懒,不想再运行一遍然后截图,当然,返回值跟任务管理器并不完全相同,是会存在一个很小的误差的,这主要受时间以及任务管理器刷新速度CPU利用率波动程度等种种方面影响。当然,如果你把任务管理器刷新速度调高,那么你会发现这个误差其实很小,小到可以忽略不记。这里就不罗嗦了,感兴趣的小伙伴可以去尝试一下,记得“要在Central Processor类实例化之前调用”。
然后dbwiddis的回复里还有一个Oshi FAQ,我就点进去简单看了下。它解释了为什么Oshi默认获取到的CPU利用率和Windows任务管理器不同。这里就不做二次阐述/翻译了,感兴趣的小伙伴可以自行探索。