温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java计算程序代码执行时间的方法有哪些

发布时间:2021-07-16 15:02:18 来源:亿速云 阅读:350 作者:小新 栏目:编程语言

小编给大家分享一下Java计算程序代码执行时间的方法有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

有时候为了排查性能问题,需要记录完成某个操作需要的时间,我们可以使用System类的currentTimeMillis()方法来返回当前的毫秒数,并保存到一个变量中,在方法执行完毕后再次调用 System的currentTimeMillis()方法,并计算两次调用之间的差值,就是方法执行所消耗的毫秒数。

如方法一:

long startTime = System.currentTimeMillis(); //获取开始时间
doSomething(); //测试的代码段
long endTime = System.currentTimeMillis(); //获取结束时间
System.out.println("程序运行时间:" + (endTime - startTime) + "ms"); //输出程序运行时间

第二种方法是以纳秒为单位计算的(使用System的nanoTime()方法):

long startTime=System.nanoTime(); //获取开始时间
doSomeThing(); //测试的代码段
long endTime=System.nanoTime(); //获取结束时间
System.out.println("程序运行时间: "+(endTime-startTime)+"ns");

示例代码一:

public static void main(String[]args){
 String str="";
 long starTime=System.currentTimeMillis();
 //计算循环10000的时间
 for(int i=0;i<10000;i++){
  str=str+i;
 }
 long endTime=System.currentTimeMillis();
 long Time=endTime-starTime;
 System.out.println(Time);
 StringBuilder bulider=new StringBuilder("");
 starTime=System.currentTimeMillis();
 for(int j=0;j<10000;j++){
  bulider.append(j);
 }
 endTime=System.currentTimeMillis();
 Time=endTime-starTime;
 System.out.println(Time);
}

示例代码二:

public class Main {
 /**
 * 计算两个时间点直接逝去的毫秒数
 *
 */
 public void computeAndDisplayElapsedTime() {
  long startTime = System.currentTimeMillis();
  for (int i = 0; i < 10; i++) {
   try {
    Thread.sleep(60);
   } catch (InterruptedException ex) {
    ex.printStackTrace();
   }
  }
  long endTime = System.currentTimeMillis();
  float seconds = (endTime - startTime) / 1000F;
  System.out.println(Float.toString(seconds) + " seconds.");
 }
 /**
 * 启动程序
 */
 public static void main(String[] args) {
  new Main().computeAndDisplayElapsedTime();
 }
}

输出结果类似:

```out
0.609 seconds.

以上是“Java计算程序代码执行时间的方法有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI