求解释一个单线程程序却占用多个CPU的现象

chichenzhe 2017-05-31 07:13:51
如何解释下面代码的CPU占用:
Map<Integer, String> map = new TreeMap<Integer, String>();
int finalnum = 0;
for (int i = 0; i < 80000000; i++) {
if(i % 500000 == 0) {
finalnum++;
Log.info("500000 puted...:" + finalnum);
}
map.put(i, "");
// finalnum = i;
}
Log.info("map made finish:" + map.size());


测试机: win7 i5 4核心无超线程. (注意,需要你提前设置eclipse所运行的JVM内存 否则跑到2000多万就跑不起来了)
代码运行第一阶段 CPU占用为25%(如果你用双核测试机 我猜应该是50%)
第二阶段 CPU占用率为80%-99%之间 (这时候我怀疑是JVM内部线程在帮我对treemap做红黑树的操作)
第三阶段 CPU占用率回到 25%
第四阶段重复第二阶段的事情 .. 如果for上十亿的话(前提你内存得够)

那么, 这是为什么呢? 为什么会表现出这样一个情况, 明明程序员只在main函数里开了一条线程给他 为什么他能把4核心的CPU吃满呢?
...全文
337 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

62,635

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧