行业资讯 2025年08月6日
0 收藏 0 点赞 192 浏览 731 个字
摘要 :

我们在Java程序开发过程中,当某个操作或方法对性能要求较高或者执行时间要求较短,经常会需要检测程序的运行时间,一般常用的方法就是在程序运行前后运行后记录当时的时……

我们在Java程序开发过程中,当某个操作或方法对性能要求较高或者执行时间要求较短,经常会需要检测程序的运行时间,一般常用的方法就是在程序运行前后运行后记录当时的时间戳,然后做减法,虽然可以比较麻烦,其实我们可以借助Spring框架中自带的StopWatch工具类来实现,那么StopWatch工具类该怎么用呢?

我们直接看案例代码,使用非常简单:

// 定义一个计数器
StopWatch stopWatch = new StopWatch("统一一组任务耗时");
// 统计任务一耗时
stopWatch.start("任务一");
TimeUnit.SECONDS.sleep(1);
stopWatch.stop();

// 统计任务二耗时
stopWatch.start("任务二");
TimeUnit.SECONDS.sleep(2);
stopWatch.stop();

// 打印出耗时
String result = stopWatch.prettyPrint();
System.err.println(result);

打印效果如下:
StopWatch ‘统一一组任务耗时’: running time (millis) = 3000

—————————————–

ms % Task name

—————————————–

01000 033% 任务一

02000 067% 任务二

代码想必大家一看就懂,就是一个StopWatch类,封装在Util包中,在执行前调用start方法,记录开始时间,执行结束后调用stop方法,记录结束时间,也可以通过getTotalTimeSeconds获取执行的秒数,其实底层还是用了System.nanoTime()这个方法,但是封装成类就显得更直观点,也更简单点,而且更方便以后的拓展。

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/8212.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

986
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

463
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

347
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

455
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

515
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

831
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号