为什么“while(true)”与“Thread.sleep”导致100%的CPU使用率?

时间:2011-11-29 06:19:40

标签: java while-loop cpu-usage

更新:我不知道为什么但它突然变得很好。现在该程序的CPU使用率仅为10%~17%。


我在java中遇到了linux背景问题 问题应该每100秒执行一次 所以我创建了一个计时器类和一些代码,如下所示:

while(true) {   
  try {
    Thread.sleep(1000 * 100);
  } catch (InterruptedException e) {
     e.printStackTrace();
  }           
}

但它仍然填满了cpu的使用。

这是整个主要的()。没有其他程序正在运行。

public static void main(String[] args) throws WeiboException, HttpException, IOException{
  timer = new Timer(true);
  timer.schedule(new Getdatatimer(), 0, 100 * 1000);

  System.out.print("runnning \n");  
  while(true) {
    try {
      Thread.sleep(1000 * 100);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }             
  }
}

计时器每100秒准确运行一次。但问题是cpu的使用。

1 个答案:

答案 0 :(得分:5)

您的代码似乎很好,不应该导致繁忙的等待。可能是其他东西正在消耗cpu,你可以通过使用探查器或检查jconsole中的堆栈跟踪来确定jvisualvm。