StopWatch使用介绍 _ JAVA
StopWatch是Spring核心包中的一个工具类,它是一个简单的秒表工具,可以计时指定代码段的运行时间以及汇总这个运行时间,使用它可以隐藏使用 System.currentTimeMillis() ,提高应用程序代码的可读性并减少计算错误的可能性。
注意事项
StopWatch对象不是设计为线程安全的,并且不使用同步。
使用场景
一般是在开发过程中验证性能,而不是作为生产应用程序的一部分
方法介绍
// 构建一个新的秒表,不开始任何任务。
public StopWatch()
//构造具有给定id的新秒表。不开始任何任务。
// 参数:id - 此秒表的标识符。当我们从多个秒表输出并需要区分它们时很方便。
public StopWatch(java.lang.String id)
//返回此秒表的ID。
public java.lang.String getId()
// 确定TaskInfo数组是否随着时间的推移而构建。当大量使用StopWatch时,将此设置为“false”,否则任务信息结构将消耗过多的内存。默认为“true”。
public void setKeepTaskList(boolean keepTaskList)
// 启动一个未命名的任务。如果stop() 调用或计时方法而不调用此方法,则结果未定义。
public void start();
// 启动命名任务。如果stop() 调用或计时方法而不调用此方法,则结果未定义。
// 参数: taskName - 要启动的任务的名称
public void start(java.lang.String taskName)
// 停止当前任务。如果在不调用至少一对start()/ stop()方法的情况下调用计时方法,则结果是不确定的 。
public void stop();
//返回秒表当前是否正在运行。
public boolean isRunning()
// 返回当前正在运行的任务的名称(如果有)。
@Nullable
public java.lang.String currentTaskName()
// 返回上一个任务所花费的时间。
public long getLastTaskTimeMillis();
// 返回上一个任务的名称。
public java.lang.String getLastTaskName()
// 将最后一个任务作为TaskInfo对象返回。
public StopWatch.TaskInfo getLastTaskInfo();
// 返回所有任务的总时间(以毫秒为单位)。
public long getTotalTimeMillis();
//返回所有任务的总时间(以秒为单位)。
public double getTotalTimeSeconds();
//返回定时任务的数量。
public int getTaskCount();
//返回执行任务的数据数组。
public StopWatch.TaskInfo [] getTaskInfo();
//返回总运行时间的简短描述。
public java.lang.String shortSummary();
// 返回一个字符串,其中包含描述所执行任务的表。
public java.lang.String prettyPrint();
//返回描述所有已执行任务的信息性字符串对于自定义报告
public java.lang.String toString();
实际应用
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());//打印简要信息
}
}
打印效果
暂停100毫秒 110 0.11
暂停200毫秒 201 0.201
暂停300毫秒 310 0.31
false
StopWatch '测试秒表': running time (millis) = 621
-----------------------------------------
ms % Task name
-----------------------------------------
00110 018% 暂停100毫秒
00201 032% 暂停200毫秒
00310 050% 暂停300毫秒
StopWatch '测试秒表': running time (millis) = 621
推荐阅读
-
4个理由告诉你Java为何排行第一
本文由码农网 –单劼原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划!Java已经有20年的历史了,甚...
-
写给精明Java开发者的测试技巧
我们都会为我们的代码编写测试,不是吗?毫无疑问,我知道这个问题的答案可能会从“当然,但你知道怎样才能避免写测试吗?”到“必须...
-
Java 微服务框架 Redkale 入门介绍
Redkale功能Redkale虽然只有1.xM大小,但是麻雀虽小五脏俱全。既可作为服务器使用,也可当工具包使用。作为独立的工...
-
Java内存管理原理及内存区域详解
一、概述Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干不同的数据区域,这些区域都有各自的用途以及创建和销毁...
-
2015年Java开发岗位面试题归类
下面是我自己收集整理的Java岗位今天面经遇到的面试题,可以用它来好好准备面试。一、Java基础1.String...
-
Java 虚拟机类加载机制和字节码执行引擎
引言我们知道java代码编译后生成的是字节码,那虚拟机是如何加载这些class字节码文件的呢?加载之后又是如何进行方法调用的呢?...
-
Java常量池理解与总结
一.相关概念什么是常量用final修饰的成员变量表示常量,值一旦给定就无法改变!final修饰的变量有三种:静态...
-
Java 实现线程死锁
概述春节的时候去面试了一家公司,笔试题里面有一道是使用简单的代码实现线程的‘死锁’,当时没有想到这道题考的是Sync...
-
Java:过去、未来的互联网编程之王
Java对你而言是什么?一门你大学里学过的语言?一个IT行业的通用语言?你相信Java已经为下一次互联网爆炸做好了准备么?Java...
-
20个高级Java面试题汇总
本文由码农网 –小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划!这是一个高级Java面试系列题中...
