StopWatch是Spring核心包中的一个工具类,它是一个简单的秒表工具,可以计时指定代码段的运行时间以及汇总这个运行时间,
使用它可以隐藏使用 System.currentTimeMillis() ,提高应用程序代码的可读性并减少计算错误的可能性。
注意事项
StopWatch对象不是设计为线程安全的,并且不使用同步。
使用场景
一般是在开发过程中验证性能,而不是作为生产应用程序的一部分
package com.wfg.boot.spring;
import org.springframework.util.StopWatch;
import java.util.Arrays;
/**
* @author wufagang
* @description
* @date 2023年09月15日 20:48
*/
public class StopWatchTest {
public static void main(String[] args) throws InterruptedException {
StopWatch stopWatch = new StopWatch("测试秒表");
stopWatch.start("暂停100毫秒");
Thread.sleep(100 * 1);
stopWatch.stop();
stopWatch.start("暂停200毫秒");
Thread.sleep(100 * 2);
stopWatch.stop();
stopWatch.start("暂停300毫秒");
Thread.sleep(100 * 3);
stopWatch.stop();
stopWatch.setKeepTaskList(true); //是否构建TaskInfo信息
Arrays.stream(stopWatch.getTaskInfo()).forEach(sw ->
System.out.println(sw.getTaskName()+" "+
sw.getTimeMillis()+" "+sw.getTimeSeconds()));
// 在start()方法和stop()方法间时,isRunning()返回true
System.out.println(stopWatch.isRunning());
System.out.println(stopWatch.prettyPrint());//打印详细信息
System.out.println(stopWatch.shortSummary());//打印简要信息
}
}