99网
您的当前位置:首页统计代码的执行时间--JAVA

统计代码的执行时间--JAVA

来源:99网

System.currentTimeMillis

Java内置的方法,使用System.currentTimeMillis来获得执行统计时间(统计单位:毫秒)

//开始时间
long stime = System.currentTimeMillis();
//执行时间(1s)
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();
//执行时间(1s)
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();
//执行时间(1s)
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();
//执行时间(1s)
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();
//执行时间(1s)
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();
//执行时间(1s)
Thread.sleep(1000);
//停止计时器
stopWatch.stop();
//统计执行时间(秒)
System.out.printf("执行时长:%d 秒.\n",stopWatch.elapsed().getSeconds());
//统计执行时间(毫秒)
System.out.printf("执行时长:%d 毫秒.\n",stopWatch.elapsed(TimeUnit.MILLISECONDS));

因篇幅问题不能全部显示,请点此查看更多更全内容