【第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利用Spire.XLS for Java设置Excel表格边框

《Java利用Spire.XLSforJava设置Excel表格边框》在日常的业务报表和数据处理中,Excel表格的美观性和可读性至关重要,本文将深入探讨如何利用Spire.XLSforJava库... 目录Spire.XLS for Java 简介与安装Maven 依赖配置手动安装 JAR 包核心API介

Java StringBuilder 实现原理全攻略

《JavaStringBuilder实现原理全攻略》StringBuilder是Java提供的可变字符序列类,位于java.lang包中,专门用于高效处理字符串的拼接和修改操作,本文给大家介绍Ja... 目录一、StringBuilder 基本概述核心特性二、StringBuilder 核心实现2.1 内部

SpringBoot AspectJ切面配合自定义注解实现权限校验的示例详解

《SpringBootAspectJ切面配合自定义注解实现权限校验的示例详解》本文章介绍了如何通过创建自定义的权限校验注解,配合AspectJ切面拦截注解实现权限校验,本文结合实例代码给大家介绍的非... 目录1. 创建权限校验注解2. 创建ASPectJ切面拦截注解校验权限3. 用法示例A. 参考文章本文

Java中字符编码问题的解决方法详解

《Java中字符编码问题的解决方法详解》在日常Java开发中,字符编码问题是一个非常常见却又特别容易踩坑的地方,这篇文章就带你一步一步看清楚字符编码的来龙去脉,并结合可运行的代码,看看如何在Java项... 目录前言背景:为什么会出现编码问题常见场景分析控制台输出乱码文件读写乱码数据库存取乱码解决方案统一使

Java Stream流与使用操作指南

《JavaStream流与使用操作指南》Stream不是数据结构,而是一种高级的数据处理工具,允许你以声明式的方式处理数据集合,类似于SQL语句操作数据库,本文给大家介绍JavaStream流与使用... 目录一、什么是stream流二、创建stream流1.单列集合创建stream流2.双列集合创建str

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具