【第22章】spring-计时器

2024-04-27 04:12
文章标签 java spring 22 计时器

本文主要是介绍【第22章】spring-计时器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、java计时
    • 1. 计时代码
    • 2. 执行结果
  • 二、spring计时
    • 1.计时代码
    • 2.执行结果
  • 总结


前言

功能优化的重点是需要缩短业务中比较耗时的模块的处理时间,首先我们需要分析出各个模块的耗时时间,接下来才能有针对的去做优化。

Spring 框架提供了一个 StopWatch 类,它用于在开发过程中测量代码执行时间。通过 StopWatch,你可以方便地记录多个任务(或代码块)的执行时间,并可以对这些时间进行统计和分析。


一、java计时

1. 计时代码

package org.example.timer;/*** Create by zjg on 2024/4/21*/
public class Timer {public static void main(String[] args) {system();}public static void system() {long task1Start = System.currentTimeMillis();// 开始一个任务System.out.println("task1执行");// 模拟任务执行try {Thread.sleep(500); // 休眠0.5秒} catch (InterruptedException e) {e.printStackTrace();}// 结束任务,并自动记录执行时间System.out.println("task1结束");long task1End = System.currentTimeMillis();// 开始另一个任务System.out.println("task2执行");long task2Start = System.currentTimeMillis();// 模拟任务执行try {Thread.sleep(1000); // 休眠1秒} catch (InterruptedException e) {e.printStackTrace();}// 结束任务,并自动记录执行时间System.out.println("task2结束");long task2End = System.currentTimeMillis();// 打印所有任务的执行时间long timer1 = task1End - task1Start;long timer2 = task2End - task2Start;System.out.println(String.format("任务1耗时:[%s]秒",timer1/1000));System.out.println(String.format("任务1耗时:[%s]毫秒",timer1));System.out.println(String.format("任务1耗时:[%s]秒",timer2/1000));System.out.println(String.format("任务2耗时:[%s]毫秒",timer2));}
}

2. 执行结果

task1执行
task1结束
task2执行
task2结束
任务1耗时:[0]秒
任务1耗时:[506]毫秒
任务1耗时:[1]秒
任务2耗时:[1007]毫秒

可以看出,计时时间单位是毫米,秒是通过运算得来的,不足1秒的值就是0秒,不够精确。

二、spring计时

1.计时代码

package org.example.timer;import org.springframework.util.StopWatch;
import java.util.Arrays;/*** Create by zjg on 2024/4/21*/
public class Timer {public static void main(String[] args) {stopWatch();}public static void stopWatch() {StopWatch stopWatch = new StopWatch();// 开始一个任务System.out.println("task1执行");stopWatch.start("task1");// 模拟任务执行try {Thread.sleep(500); // 休眠0.5秒} catch (InterruptedException e) {e.printStackTrace();}// 结束任务,并自动记录执行时间System.out.println("task1结束");stopWatch.stop();// 开始另一个任务System.out.println("task2执行");stopWatch.start("task2");// 模拟任务执行try {Thread.sleep(1000); // 休眠1秒} catch (InterruptedException e) {e.printStackTrace();}// 结束任务,并自动记录执行时间System.out.println("task2结束");stopWatch.stop();StopWatch.TaskInfo[] taskInfo = stopWatch.getTaskInfo();Arrays.stream(taskInfo).toList().forEach((taskInfo1 -> {System.out.println(String.format("任务[%s],耗时[%s]秒",taskInfo1.getTaskName(),taskInfo1.getTimeSeconds()));System.out.println(String.format("任务[%s],耗时[%s]毫秒",taskInfo1.getTaskName(),taskInfo1.getTimeMillis()));System.out.println(String.format("任务[%s],耗时[%s]纳秒",taskInfo1.getTaskName(),taskInfo1.getTimeNanos()));}));// 打印所有任务的执行时间System.out.println(stopWatch.prettyPrint());}
}

2.执行结果

task1执行
task1结束
task2执行
task2结束
任务[task1],耗时[0.5026385]秒
任务[task1],耗时[502]毫秒
任务[task1],耗时[502638500]纳秒
任务[task2],耗时[1.0009278]秒
任务[task2],耗时[1000]毫秒
任务[task2],耗时[1000927800]纳秒
StopWatch '': running time = 1503566300 ns
---------------------------------------------
ns         %     Task name
---------------------------------------------
502638500  033%  task1
1000927800  067%  task2

spring计时器为我们提供了秒、毫秒、纳秒三种时间单位,并帮我们列出了多个任务的耗时百分比情况,相对较友好。


总结

回到顶部

计时任务其实是个切面问题,我们需要分析、跟踪系统中大量接口的交易时间、平均时间、超时时间等等。

这篇关于【第22章】spring-计时器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/939486

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2