System.currentTimeMillis
Java内置的方法,使用System.currentTimeMillis来获得执行统计时间(统计单位:毫秒)
long stime = System.currentTimeMillis();
Thread.sleep(1000);
long etime = System.currentTimeMillis();
System.out.printf("执行时长:%d 毫秒.",(etime-stime));
System.nanoTime
此方法为 Java 内置的方法,使用 System.nanoTime 来统计执行时间(统计单位:纳秒,1 毫秒 = 100 万纳秒。),它的执行方法和 System.currentTimeMillis 类似,示例代码如下:
long stime = System.nanoTime();
Thread.sleep(1000);
long etime = System.nanoTime();
System.out.printf("执行时长:%d 纳秒.",(etime-stime));
new Date
此方法也是 Java 的内置方法,在开始执行前 new Date() 创建一个当前时间对象,在执行结束之后 new Date() 一个当前执行时间,然后再统计两个 Date 的时间间隔,示例代码如下:
Date sdate = new Date();
Thread.sleep(1000);
Date edate = new Date();
System.out.printf("执行时长:%d 毫秒.",(edate.getTime()-sdate.getTime()));
Spring StopWatch
如果我们使用的是 Spring 或 Spring Boot 项目,可以在项目中直接使用 StopWatch 对象来统计代码执行时间,示例代码如下:
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());
Thread#sleep 方法的执行时间稍有偏差,在 1s 左右都是正常的。
commons-lang3 StopWatch
如果我们使用的是普通项目,那我们可以用 Apache commons-lang3 中的 StopWatch 对象来实现时间统计,首先先添加 commons-lang3 的依赖:
<!-- https://mvnrepository.com/artifact/org.apache.commons-lang3 -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.10</version>
</dependency>
然后统计时间
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) + " 纳秒。");
Guava Stopwatch
除了 Apache 的 commons-lang3 外,还有一个常用的 Java 工具包,那就是 Google 的 Guava,Guava 中也包含了 Stopwatch 统计类。首先先添加 Guava 的依赖:
<!-- https://mvnrepository.com/artifact/com.google.guava/guava -->
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>29.0-jre</version>
</dependency>
然后统计时间
StopWatch stopWatch = StopWatch.createStarted();
Thread.sleep(1000);
stopWatch.stop();
System.out.printf("执行时长:%d 秒.\n",stopWatch.elapsed().getSeconds());
System.out.printf("执行时长:%d 毫秒.\n",stopWatch.elapsed(TimeUnit.MILLISECONDS));