(转载)Java统计代码的执行时间的6种方法
(37条消息) Java统计代码的执行时间的6种方法_年少青山的博客-CSDN博客_java记录程序执行时间

方法一:System.currentTimeMillis
此方法为 Java 内置的方法,使用 System#currentTimeMillis 来统计执行的时间(统计单位:毫秒),示例代码如下:


方法二:System.nanoTime
此方法为 Java 内置的方法,使用 System#nanoTime 来统计执行时间(统计单位:纳秒),它的执行方法和 System#currentTimeMillis 类似,示例代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13
   | public class TimeIntervalTest {     public static void main(String[] args) throws InterruptedException {                  long stime = System.nanoTime();                  Thread.sleep(1000);                  long etime = System.nanoTime();                  System.out.printf("执行时长:%d 纳秒.", (etime - stime));     } }
 
  | 
 
执行时长:1000769200 纳秒.
小贴士:1 毫秒 = 100 万纳秒。
方法三:new Date
此方法也是 Java 的内置方法,在开始执行前 new Date() 创建一个当前时间对象,在执行结束之后 new Date() 一个当前执行时间,然后再统计两个 Date 的时间间隔,示例代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14
   | import java.util.Date;   public class TimeIntervalTest {     public static void main(String[] args) throws InterruptedException {                  Date sdate = new Date();                  Thread.sleep(1000);                  Date edate = new Date();                  System.out.printf("执行时长:%d 毫秒." , (edate.getTime() - sdate.getTime()));      } }
   | 
 
执行时长:1000 毫秒
方法四:Spring StopWatch
如果我们使用的是 Spring 或 Spring Boot 项目,可以在项目中直接使用 StopWatch 对象来统计代码执行时间,示例代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13
   | StopWatch stopWatch = new StopWatch();
  stopWatch.start();
  Thread.sleep(1000);
  stopWatch.stop();
  System.out.printf("执行时长:%d 秒.%n", stopWatch.getTotalTimeSeconds()); 
  System.out.printf("执行时长:%d 毫秒.%n", stopWatch.getTotalTimeMillis()); 
  System.out.printf("执行时长:%d 纳秒.%n", stopWatch.getTotalTimeNanos());
   | 
 
执行时长:0.9996313 秒. 执行时长:999 毫秒. 执行时长:999631300 纳秒.
小贴士:Thread#sleep 方法的执行时间稍有偏差,在 1s 左右都是正常的。
方法五:commons-lang3 StopWatch
如果我们使用的是普通项目,那我们可以用 Apache commons-lang3 中的 StopWatch 对象来实现时间统计,首先先添加 commons-lang3 的依赖:
1 2 3 4 5 6
   |  <dependency>   <groupId>org.apache.commons</groupId>   <artifactId>commons-lang3</artifactId>   <version>3.10</version> </dependency>
 
  | 
 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
   | import org.apache.commons.lang3.time.StopWatch;   import java.util.concurrent.TimeUnit;   public class TimeIntervalTest {     public static void main(String[] args) throws InterruptedException {         StopWatch stopWatch = new StopWatch();                  stopWatch.start();                  Thread.sleep(1000);                  stopWatch.stop();                  System.out.println("执行时长:" + stopWatch.getTime(TimeUnit.SECONDS) + " 秒.");                  System.out.println("执行时长:" + stopWatch.getTime(TimeUnit.MILLISECONDS) + " 毫秒.");                  System.out.println("执行时长:" + stopWatch.getTime(TimeUnit.NANOSECONDS) + " 纳秒.");     } }
 
   | 
 
执行时长:1 秒. 执行时长:1000 毫秒.
执行时长:1000555100 纳秒.
方法六:Guava Stopwatch
除了 Apache 的 commons-lang3 外,还有一个常用的 Java 工具包,那就是 Google 的 Guava,Guava 中也包含了  Stopwatch 统计类。首先先添加 Guava 的依赖:
1 2 3 4 5 6
   |  <dependency>   <groupId>com.google.guava</groupId>   <artifactId>guava</artifactId>   <version>29.0-jre</version> </dependency>
 
  | 
 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
   | import com.google.common.base.Stopwatch;   import java.util.concurrent.TimeUnit;   public class TimeIntervalTest {     public static void main(String[] args) throws InterruptedException {                  Stopwatch stopwatch = Stopwatch.createStarted();                  Thread.sleep(1000);                  stopwatch.stop();                  System.out.printf("执行时长:%d 秒. %n", stopwatch.elapsed().getSeconds());                   System.out.printf("执行时长:%d 豪秒.", stopwatch.elapsed(TimeUnit.MILLISECONDS));     } }
   | 
 
执行时长:1 秒.
执行时长:1000 豪秒.
总结
本文介绍了 6 种实现代码统计的方法,其中 3 种是 Java 内置的方法:
System.currentTimeMillis()
System.nanoTime()
new Date()
还介绍了 3 种常用框架 spring、commons-langs3、guava 的时间统计器 StopWatch。
在没有用到 spring、commons-langs3、guava 任意一种框架的情况下,推荐使用 System.currentTimeMillis() 或 System.nanoTime() 来实现代码统计,否则建议直接使用 StopWatch 对象来统计执行时间。
知识扩展—Stopwatch 让统计更方便
StopWatch 存在的意义是让代码统计更简单,比如 Guava 中 StopWatch 使用示例如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
   | import com.google.common.base.Stopwatch;   import java.util.concurrent.TimeUnit;   public class TimeIntervalTest {     public static void main(String[] args) throws InterruptedException {                  Stopwatch stopwatch = Stopwatch.createStarted();                  Thread.sleep(1000);                  stopwatch.stop();                  System.out.printf("执行时长:%d 毫秒. %n",                 stopwatch.elapsed(TimeUnit.MILLISECONDS));                  stopwatch.reset();                  stopwatch.start();                  Thread.sleep(2000);                  stopwatch.stop();                  System.out.printf("执行时长:%d 秒. %n",                 stopwatch.elapsed(TimeUnit.MILLISECONDS));     } }
   |