首页 > Java > 如何在 Java 中计时方法的执行时间?

如何在 Java 中计时方法的执行时间?

上一篇 下一篇

  1. 如何获取方法的执行时间?
  2. 是否有一个实用程序类用于计时任务需要多长时间等?Timer

Google上的大多数搜索都会返回调度线程和任务的计时器的结果,这不是我想要的。

分割线

网友回答:

我接受简单的答案。为我工作。

long startTime = System.currentTimeMillis();

doReallyLongThing();

long endTime = System.currentTimeMillis();

System.out.println("That took " + (endTime - startTime) + " milliseconds");

效果很好。分辨率显然只有毫秒,你可以用System.nanoTime()做得更好。两者都有一些限制(操作系统计划切片等),但这效果很好。

在几次运行中平均(越多越好),你会得到一个不错的主意。

分割线

网友回答:

总有老式的方式:

long startTime = System.nanoTime();
methodToTime();
long endTime = System.nanoTime();

long duration = (endTime - startTime);  //divide by 1000000 to get milliseconds.

分割线

网友回答:

来吧伙计们!没有人提到番石榴的方法(这可以说很棒):

import com.google.common.base.Stopwatch;

Stopwatch timer = Stopwatch.createStarted();
//method invocation
LOG.info("Method took: " + timer.stop());

好消息是 Stopwatch.toString() 在选择测量时间单位方面做得很好。即,如果值很小,它将输出 38 ns,如果它很长,它将显示 5m 3s

甚至更好:

Stopwatch timer = Stopwatch.createUnstarted();
for (...) {
   timer.start();
   methodToTrackTimeFor();
   timer.stop();
   methodNotToTrackTimeFor();
}
LOG.info("Method took: " + timer);

注意:Google Guava需要Java 1.6+

模板简介:该模板名称为【如何在 Java 中计时方法的执行时间?】,大小是暂无信息,文档格式为.编程语言,推荐使用Sublime/Dreamweaver/HBuilder打开,作品中的图片,文字等数据均可修改,图片请在作品中选中图片替换即可,文字修改直接点击文字修改即可,您也可以新增或修改作品中的内容,该模板来自用户分享,如有侵权行为请联系网站客服处理。欢迎来懒人模板【Java】栏目查找您需要的精美模板。

相关搜索
  • 下载密码 lanrenmb
  • 下载次数 192次
  • 使用软件 Sublime/Dreamweaver/HBuilder
  • 文件格式 编程语言
  • 文件大小 暂无信息
  • 上传时间 03-12
  • 作者 网友投稿
  • 肖像权 人物画像及字体仅供参考
栏目分类 更多 >
热门推荐 更多 >
自适应 单页式简历模板 响应式 微信文章 html5 微信素材 企业网站 微信模板 微信公众平台 微信图片
您可能会喜欢的其他模板