java执行时间_Java计算程序代码执行时间的方法小结

本文实例总结了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程序设计有所帮助。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值