用StopWatch優(yōu)雅替代currentTimeMillis計(jì)算程序執(zhí)行耗時(shí)
需求
有時(shí)需要記錄程序執(zhí)行時(shí)間,最簡(jiǎn)單就是打印當(dāng)前時(shí)間與執(zhí)行完時(shí)間的差值,缺點(diǎn)是:
- 執(zhí)行大量測(cè)試的話就很麻煩
- 不直觀
- 如果想對(duì)執(zhí)行的時(shí)間做進(jìn)一步控制,則需要在程序中很多地方修改
于是 Spring提供了一個(gè)StopWatch類(lèi)可以做類(lèi)似任務(wù)執(zhí)行時(shí)間控制,即封裝了一個(gè)對(duì)開(kāi)始時(shí)間,結(jié)束時(shí)間記錄工具
案例
統(tǒng)計(jì)輸出總耗時(shí)
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());
}
}
輸出最后一個(gè)任務(wù)的耗時(shí)
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());
}
}
以?xún)?yōu)雅的格式打出所有任務(wù)的耗時(shí)以及占比
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());
}
}
序列服務(wù)輸出耗時(shí)信息
@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() 獲取總耗時(shí)秒,同時(shí)也有獲取毫秒的方法
prettyPrint() 優(yōu)雅的格式打印結(jié)果,表格形式
shortSummary() 返回簡(jiǎn)短的總耗時(shí)描述
getTaskCount() 返回統(tǒng)計(jì)時(shí)間任務(wù)的數(shù)量
getLastTaskInfo().getTaskName() 返回最后一個(gè)任務(wù)TaskInfo對(duì)象的名稱(chēng)
到此這篇關(guān)于用StopWatch優(yōu)雅替代currentTimeMillis計(jì)算程序執(zhí)行耗時(shí)的文章就介紹到這了,更多相關(guān)Java StopWatch內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Maven添加Tomcat插件實(shí)現(xiàn)熱部署代碼實(shí)例
這篇文章主要介紹了Maven添加Tomcat插件實(shí)現(xiàn)熱部署代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04
IDEA創(chuàng)建SpringBoot的maven項(xiàng)目的方法步驟
這篇文章主要介紹了IDEA創(chuàng)建SpringBoot的maven項(xiàng)目的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
使用Java校驗(yàn)SQL語(yǔ)句的合法性五種解決方案
這篇文章主要介紹了如何用java校驗(yàn)SQL語(yǔ)句的合法性(提供五種解決方案),使用JDBC?API和JSqlParser庫(kù)、正則表達(dá)式、ANTLR解析器生成器或Apache?Calcite庫(kù)都可以實(shí)現(xiàn)校驗(yàn)SQL語(yǔ)句的合法性,需要的朋友可以參考下2023-04-04
Java類(lèi)加載之Class對(duì)象到Klass模型詳解
這篇文章主要介紹了Java類(lèi)加載之Class對(duì)象到Klass模型詳解,每一個(gè)Java類(lèi)在JVM中都會(huì)對(duì)應(yīng)創(chuàng)建一個(gè)C++類(lèi)實(shí)例,我們稱(chēng)這個(gè)C++類(lèi)為Klass實(shí)例,Klass實(shí)例里面存儲(chǔ)了java類(lèi)中所描述的方法、字段、屬性等,需要的朋友可以參考下2023-08-08
Spring Junit測(cè)試找不到SpringJUnit4ClassRunner.class的解決
這篇文章主要介紹了Spring Junit測(cè)試找不到SpringJUnit4ClassRunner.class的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
Bean的自動(dòng)注入及循環(huán)依賴(lài)問(wèn)題
本文詳細(xì)介紹了Bean的自動(dòng)注入及循環(huán)依賴(lài),文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)有一定的研究?jī)r(jià)值,感興趣的小伙伴可以閱讀參考2023-03-03

