别再用System.currentTimeMillis()!拥抱StopWatch优雅计算程序执行耗时

简介: 别再用System.currentTimeMillis()!拥抱StopWatch优雅计算程序执行耗时

需求

有时需要记录程序执行时间,最简单就是打印当前时间与执行完时间的差值,缺点是:


  • 执行大量测试的话就很麻烦
  • 不直观
  • 如果想对执行的时间做进一步控制,则需要在程序中很多地方修改


于是 Spring提供了一个StopWatch类可以做类似任务执行时间控制,即封装了一个对开始时间,结束时间记录工具

案例


统计输出总耗时

import org.springframework.util.StopWatch;
public class SpringStopWatchExample {
    public static void main (String[] args) throws InterruptedException {
        StopWatch sw = new StopWatch();
        sw.start();
        //long task simulation
        Thread.sleep(1000);
        sw.stop();
        System.out.println(sw.getTotalTimeMillis());
    }
}

输出最后一个任务的耗时

public class SpringStopWatchExample2 {
    public static void main (String[] args) throws InterruptedException {
        StopWatch sw = new StopWatch();
        sw.start("A");//setting a task name
        //long task simulation
        Thread.sleep(1000);
        sw.stop();
        System.out.println(sw.getLastTaskTimeMillis());
    }
}


以优雅的格式打出所有任务的耗时以及占比

import org.springframework.util.StopWatch;
public class SpringStopWatchExample3 {
    public static void main (String[] args) throws InterruptedException {
        StopWatch sw = new StopWatch();
        sw.start("A");
        Thread.sleep(500);
        sw.stop();
        sw.start("B");
        Thread.sleep(300);
        sw.stop();
        sw.start("C");
        Thread.sleep(200);
        sw.stop();
        System.out.println(sw.prettyPrint());
    }
}

序列服务输出耗时信息

@Override
public long nextSeq(String name) {
    StopWatch watch = new StopWatch();
    watch.start("单序列获取总消耗");
    long sequence = generator.generateId(name);
    watch.stop();
    logger.info(watch.prettyPrint());
    return sequence;
}

getTotalTimeSeconds() 获取总耗时秒,同时也有获取毫秒的方法

prettyPrint() 优雅的格式打印结果,表格形式

shortSummary() 返回简短的总耗时描述

getTaskCount() 返回统计时间任务的数量

getLastTaskInfo().getTaskName() 返回最后一个任务TaskInfo对象的名称


目录
相关文章
|
1月前
|
Java API Spring
Java小抄 使用StopWatch输出执行耗时
通过本文的介绍,我们详细讲解了如何使用 `StopWatch` 类测量代码执行时间。`StopWatch` 提供了简单而强大的功能,帮助我们精确分析代码的性能瓶颈,优化程序效率。希望本文能帮助您更好地理解和应用 `StopWatch`,在实际开发中提高代码性能和质量。
165 80
|
安全 Java
灵魂拷问:你真的理解System.out.println()打印原理吗?
灵魂拷问:你真的理解System.out.println()打印原理吗?
146 0
用StopWatch 统计代码耗时
用StopWatch 统计代码耗时
138 0
用StopWatch 统计代码耗时
|
Java
Java | 使用 StopWatch 优雅打印执行耗时
Java | 使用 StopWatch 优雅打印执行耗时
1604 0
|
小程序 Java Apache
别再用 System.currentTimeMillis() 统计耗时了,太 Low,StopWatch 好用到爆!
别再用 System.currentTimeMillis() 统计耗时了,太 Low,StopWatch 好用到爆!
246 0
别再用 System.currentTimeMillis() 统计耗时了,太 Low,StopWatch 好用到爆!
|
缓存 Java Linux
System.currentTimeMillis() 和 System.nanoTime() 哪个更快?别用错了!
System.currentTimeMillis() 和 System.nanoTime() 哪个更快?别用错了!
241 0
|
JavaScript Dubbo 小程序
还在用 System.currentTimeMillis() 统计代码耗时?太 Low 啦
还在用 System.currentTimeMillis() 统计代码耗时?太 Low 啦
|
缓存 Java Linux
注意了!System.currentTimeMillis() 存在性能问题...
System.currentTimeMillis()是极其常用的基础Java API,广泛地用来获取时间戳或测量代码执行时长等,在我们的印象中应该快如闪电。 但实际上在并发调用或者特别频繁调用它的情况下(比如一个业务繁忙的接口,或者吞吐量大的需要取得时间戳的流式程序),其性能表现会令人大跌眼镜。
注意了!System.currentTimeMillis() 存在性能问题...
|
Java Spring
统计代码耗时的工具 StopWatch
项目中通常会通过打印时间来查看某段任务的耗时,进行项目优化
781 0
|
缓存 分布式计算 应用服务中间件
一次job的耗时优化经历
说起这次优化,有点奇葩,从耗时12小时到1分钟,优化经历了三次,和自己纠结了N次,看看结果还算安慰。
2280 0