当前位置: 首页 > news >正文

Spring:StopWatch

文章目录

  • 一、介绍
  • 二、使用
    • 1、导入相关的Spring包
    • 2、创建StopWatch实例和开始计时
    • 3、停止计时
    • 4、获取时间
    • 5、获取任务详情
    • 6、分阶段计时
    • 7、获取总耗时与各阶段耗时
  • 三、案例

一、介绍

在Spring框架中,StopWatch类通常用于测量代码块的执行时间。您可以使用StopWatch来计算方法调用或代码块的执行时间,以便进行性能分析和优化。

二、使用

您可以按照以下步骤在Spring应用程序中使用StopWatch:

1、导入相关的Spring包

如果你正在使用Spring Boot,那么StopWatch应该已经包含在Spring Boot的starter中。如果你不是使用Spring Boot,你可能需要手动添加Spring Context的依赖。

import org.springframework.util.StopWatch;

2、创建StopWatch实例和开始计时

在需要测量时间的代码块中创建StopWatch实例并开始计时

//使用new StopWatch()来创建一个新的StopWatch实例。
StopWatch stopWatch = new StopWatch();
//使用start()方法开始计时。通常,你会在开始执行你想要测量的代码块之前调用这个方法。
stopWatch.start();
// 执行需要测量时间的代码块

3、停止计时

使用stop()方法停止计时。这个方法会停止当前的计时器,并将此次测量的时间添加到总时间中

stopWatch.stop();

4、获取时间

你可以使用getTotalTimeMillis()或getTotalTimeSeconds()方法来获取总时间,或者使用getLastTaskTimeMillis()或getLastTaskTimeSeconds()方法来获取最后一次任务的时间。

System.out.println("Total time taken: " + stopWatch.getTotalTimeMillis() + "ms");

5、获取任务详情

StopWatch还提供了getTaskInfo()方法,用于获取每个任务的信息,包括任务名称和执行时间。

6、分阶段计时

允许在同一个StopWatch实例中开始多个“任务”,每个任务代表一个独立的计时期间,这样可以计算出不同阶段的耗时。

7、获取总耗时与各阶段耗时

提供了获取所有任务累计运行时间和单个任务运行时间的方法。

三、案例

package chatpter02;import org.springframework.util.StopWatch;import java.util.Arrays;public class TestStopWatch {public static void main(String[] args) {StopWatch stopWatch = new StopWatch();// 开始计时stopWatch.start("task1");// 执行一些任务...try {Thread.sleep(1000); // 模拟耗时任务} catch (InterruptedException e) {e.printStackTrace();}// 停止计时stopWatch.stop();// 开始另一个任务的计时stopWatch.start("task2");// 执行另一个任务...try {Thread.sleep(500); // 模拟另一个耗时任务} catch (InterruptedException e) {e.printStackTrace();}// 停止计时stopWatch.stop();// 输出总时间和每个任务的时间System.out.println("Total time: " + stopWatch.getTotalTimeMillis() + " ms");System.out.println("Task 2 time: " + stopWatch.getLastTaskTimeMillis() + " ms");//System.out.println("Task 2 time: " + stopWatch.get("task2") + " ms");// 获取任务信息Arrays.stream(stopWatch.getTaskInfo()).forEach(taskInfo -> {System.out.println("Task name: " + taskInfo.getTaskName());System.out.println("Task time: " + taskInfo.getTimeMillis());});}}

结果:
在这里插入图片描述

http://www.lryc.cn/news/318756.html

相关文章:

  • 考研C语言复习进阶(5)
  • [uni-app] 小程序码转为二维码, 小程序解析此码获取数据
  • 【四 (3)数据可视化之 Seaborn 常用图表及代码实现 】
  • ASP.NET-Server.HtmlEncode
  • Linux下进行JavaEE开发-安装JDK、Tomcat、MySQL
  • 视频和图像编码标准或格式的发展关系
  • 移动云行动:5.5G技术引领数字化转型
  • Git如何与Gitee连接(主) , Git的基础使用方式简述(次)
  • 使用VLC实现自动播放视频
  • KY199 查找
  • html5播放flv视频
  • 【知识简略】 简单理解SpringCloud微服务架构:服务注册发现、配置中心、限流、熔断、降级、网关路由等
  • 福派斯课堂:选择黑背犬的狗粮时需要注意哪些细节?
  • Python QT 之PySide6简单入门
  • 美团大规模KV存储挑战与架构实践
  • 计算机基础1-汇编基础
  • 六、项目进度管理
  • java操作HBase
  • 【MATLAB】语音信号识别与处理:移动中位数滤波算法去噪及谱相减算法呈现频谱
  • 浏览器 实现文件下载 完成回调 兼容ie11
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Grid)
  • Docker使用(四)Docker常见问题分析和解决收集整理
  • 通过spring boot/redis/aspect 防止表单重复提交【防抖】
  • C++ 作业 24/3/14
  • 新品牌推广怎么做?百度百科创建是第一站
  • k8s系列-kubectl 命令快速参考
  • 微信小程序--开启下拉刷新页面
  • 【研发日记】Matlab/Simulink技能解锁(五)——Simulink布线技巧
  • FPGA高端项目:FPGA基于GS2971+GS2972架构的SDI视频收发+OSD动态字符叠加,提供1套工程源码和技术支持
  • 面向对象编程第二式:继承 (Java篇)