⭐⭐⭐ Spring Boot 项目实战 ⭐⭐⭐ Spring Cloud 项目实战
《Dubbo 实现原理与源码解析 —— 精品合集》 《Netty 实现原理与源码解析 —— 精品合集》
《Spring 实现原理与源码解析 —— 精品合集》 《MyBatis 实现原理与源码解析 —— 精品合集》
《Spring MVC 实现原理与源码解析 —— 精品合集》 《数据库实体设计合集》
《Spring Boot 实现原理与源码解析 —— 精品合集》 《Java 面试题 + Java 学习指南》

摘要: 原创出处 ningyu1.github.io/20190505/116-stop-watch.html 「凝雨」欢迎转载,保留摘要,谢谢!


🙂🙂🙂关注**微信公众号:【芋道源码】**有福利:

  1. RocketMQ / MyCAT / Sharding-JDBC 所有源码分析文章列表
  2. RocketMQ / MyCAT / Sharding-JDBC 中文注释源码 GitHub 地址
  3. 您对于源码的疑问每条留言将得到认真回复。甚至不知道如何读源码也可以请教噢
  4. 新的源码解析文章实时收到通知。每周更新一篇左右
  5. 认真的源码交流微信群。

01、背景

有时我们在做开发的时候需要记录每个任务执行时间,或者记录一段代码执行时间,最简单的方法就是打印当前时间与执行完时间的差值,然后这样如果执行大量测试的话就很麻烦,并且不直观,如果想对执行的时间做进一步控制,则需要在程序中很多地方修改,目前spring-framework提供了一个StopWatch类可以做类似任务执行时间控制,也就是封装了一个对开始时间,结束时间记录工具

02、示例

我们来看几个示例

03、统计输出总耗时

import org.springframework.util.StopWatch;

public class SpringStopWatchExample {

public static void main (String[] args) throws InterruptedException {
StopWatch sw = new StopWatch();
sw.start();
//long task simulation
Thread.sleep(1000);
sw.stop();
System.out.println(sw.getTotalTimeMillis());
}
}

输出

1013

04、输出最后一个任务的耗时

public class SpringStopWatchExample2 {

public static void main (String[] args) throws InterruptedException {
StopWatch sw = new StopWatch();
sw.start("A");//setting a task name
//long task simulation
Thread.sleep(1000);
sw.stop();
System.out.println(sw.getLastTaskTimeMillis());
}
}

输出

1009

05、以优雅的格式打出所有任务的耗时以及占比

import org.springframework.util.StopWatch;

public class SpringStopWatchExample3 {

public static void main (String[] args) throws InterruptedException {
StopWatch sw = new StopWatch();
sw.start("A");
Thread.sleep(500);
sw.stop();
sw.start("B");
Thread.sleep(300);
sw.stop();
sw.start("C");
Thread.sleep(200);
sw.stop();
System.out.println(sw.prettyPrint());
}
}

输出

StopWatch '': running time (millis) = 1031
-----------------------------------------
ms % Task name
-----------------------------------------
00514 050% A
00302 029% B
00215 021% C

06、序列服务输出耗时信息

@Override
public long nextSeq(String name) {
StopWatch watch = new StopWatch();
watch.start("单序列获取总消耗");
long sequence = generator.generateId(name);
watch.stop();
logger.info(watch.prettyPrint());
return sequence;
}

07、更多用法

不同的打印结果

  1. getTotalTimeSeconds() 获取总耗时秒,同时也有获取毫秒的方法
  2. prettyPrint() 优雅的格式打印结果,表格形式
  3. shortSummary() 返回简短的总耗时描述
  4. getTaskCount() 返回统计时间任务的数量
  5. getLastTaskInfo().getTaskName() 返回最后一个任务TaskInfo对象的名称

08、总结

以后我们统计代码执行效率建议大家都使用这个工具来进行输出,不需要在starttime、endtime再相减计算,用优雅的方式来完成这件事情。

文章目录
  1. 1. 01、背景
  2. 2. 02、示例
  3. 3. 03、统计输出总耗时
  4. 4. 04、输出最后一个任务的耗时
  5. 5. 05、以优雅的格式打出所有任务的耗时以及占比
  6. 6. 06、序列服务输出耗时信息
  7. 7. 07、更多用法
  8. 8. 08、总结