网站首页 > 技术文章 正文
背景
你还在用 System.currentTimeMillis... 统计耗时?
比如下面这段代码:
/**
* @author: 栈长
* @from: 公众号Java技术栈
*/
@Test
public void jdkWasteTime() throws InterruptedException {
long start = System.currentTimeMillis();
Thread.sleep(3000);
System.out.printf("耗时:%dms.", System.currentTimeMillis() - start);
}
System.currentTimeMillis...这种方式统计耗时确实是用的最多的,因为它不用引入其他的 JAR 包,JDK 就能搞定,但是它用起来有几个不方便的地方:
1)需要定义初始时间值,再用当前时间进行手工计算;
2)统计多个任务的耗时比较麻烦,如果 start 赋值搞错可能还会出现逻辑问题;
有没有其他的更好的替代方案呢?答案是肯定的:StopWatch!
StopWatch
StopWatch 是一个统计耗时的工具类:
常用的 StopWatch 工具类有以下两种:
- commons-lang3(Apache 提供的通用工具包)
- spring-core(Spring 核心包)
虽然两个工具类的名称是一样的,但是用法大不相同,本文栈长就给大家分别演示下。
commons-lang3 提供的 StopWatch
引入依赖
commons-lang3 是 Apache 开源的通用工具包,需要额外引入 Maven 依赖:
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>${commons-lang3.version}</version>
</dependency>
简单示例
创建一个 StopWatch 实例有以下 3 种方法:
1) 使用 new 关键字
StopWatch sw = new StopWatch();
2)使用 create 工厂方法
StopWatch sw = StopWatch.create();
3)使用 createStarted 方法
StopWatch sw = StopWatch.createStarted();
这个方法不但会创建一个实例,同时还会启动计时。
来看一个简单的例子:
// 创建一个 StopWatch 实例并开始计时
StopWatch sw = StopWatch.createStarted();
// 休眠1秒
Thread.sleep(1000);
// 1002ms
System.out.printf("耗时:%dms.\n", sw.getTime());
更多用法
接之前的示例继续演示。
暂停计时:
// 暂停计时
sw.suspend();
Thread.sleep(1000);
// 1000ms
System.out.printf("暂停耗时:%dms.\n", sw.getTime());
因为暂停了,所以还是 1000ms,暂停后中间休眠的 1000 ms 不会被统计。
恢复计时:
// 恢复计时
sw.resume();
Thread.sleep(1000);
// 2001ms
System.out.printf("恢复耗时:%dms.\n", sw.getTime());
因为恢复了,结果是 2001 ms,恢复后中间休眠的 1000 ms 被统计了。
停止计时:
Thread.sleep(1000);
// 停止计时
sw.stop();
Thread.sleep(1000);
// 3009ms
System.out.printf("总耗时:%dms.\n", sw.getTime());
停止计时前休眠了 1000ms,所以结果是 3009ms,停止计时后就不能再使用暂停、恢复功能了。
重置计时:
// 重置计时
sw.reset();
// 开始计时
sw.start();
Thread.sleep(1000);
// 1000ms
System.out.printf("重置耗时:%dms.\n", sw.getTime());
因为重置计时了,所以重新开始计时后又变成了 1000ms。
本文所有完整示例源代码已经上传:
https://github.com/javastacks/javastack
欢迎 Star 学习,后面 Java 示例都会在这上面提供!另外,最新面试题整理好了,大家可以在Java面试库小程序在线刷题。
Spring 提供的 StopWatch
来看一个简单的例子:
// 创建一个 StopWatch 实例
StopWatch sw = StopWatch("公众号Java技术栈:测试耗时");
// 开始计时
sw.start("任务1");
// 休眠1秒
Thread.sleep(1000);
// 停止计时
sw.stop();
// 1002ms
System.out.printf("任务1耗时:%d%s.\n", sw.getLastTaskTimeMillis(), "ms");
Spring 创建实例的方法就是 new,开始计时,以及获取时间需要手动 start、stop。
继续再新增 2 个任务:
Thread.sleep(1000);
sw.start("任务2");
Thread.sleep(1100);
sw.stop();
// 1100ms.
System.out.printf("任务2耗时:%d%s.\n", sw.getLastTaskTimeMillis(), "ms");
sw.start("任务3");
Thread.sleep(1200);
sw.stop();
// 1203ms.
System.out.printf("任务3耗时:%d%s.\n", sw.getLastTaskTimeMillis(), "ms");
// 3.309373456s.
System.out.printf("任务数量:%s,总耗时:%ss.\n", sw.getTaskCount(), sw.getTotalTimeSeconds());
Spring 一个重要的亮点是支持格式化打印结果:
System.out.println(sw.prettyPrint());
来看最后的输出结果:
不过有一点不友好的是,格式化结果显示的是纳秒,而且不能修改。
猜你喜欢
- 2024-09-20 非常详细!如何理解表格存储的多版本、生命周期和有效版本偏差
- 2024-09-20 6种快速统计代码执行时间的方法,真香
- 2024-09-20 Java 开发者最困惑的四件事(java开发遇到问题如何解决)
- 2024-09-20 【Java多线程】定时器Timer(java定时器线程池)
- 2024-09-20 还在用new Date计算任务执行时间?强烈建议使用这个API
- 2024-09-20 “抄”代码,再也不用上谷歌复制粘贴了
- 2024-09-20 java获取当前时间的四种方法代码实例
- 2024-09-20 撸完这篇线程池,我快咳血了(线程池有什么用)
- 2024-09-20 JAVA轮询遍历两个数组进行比较(遍历数组 java)
- 2024-09-20 蒙圈了?System.currentTimeMillis()存在性能问题
- 1514℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 563℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 508℃MySQL service启动脚本浅析(r12笔记第59天)
- 486℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 485℃启用MySQL查询缓存(mysql8.0查询缓存)
- 465℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 445℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 442℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)