GUAVA STOPWATCH源碼解析

問題

一直在使用如下代碼進(jìn)行程序耗時(shí)計(jì)算和性能調(diào)試同仆,但是對其返回值代表的具體意義卻不甚了解。

Stopwatch stopwatch = Stopwatch.createStarted();
doSomething();
stopwatch.stop(); // optional
long millis = stopwatch.elapsed(MILLISECONDS);
log.info("time: " + stopwatch); // formatted string like "12.3 ms"

查看源碼發(fā)現(xiàn)其代碼并不復(fù)雜惫叛,下面就對其源碼進(jìn)行剖析和解釋当凡。

源碼剖析

public final class Stopwatch {
  private final Ticker ticker;//計(jì)時(shí)器,用于獲取當(dāng)前時(shí)間
  private boolean isRunning;//計(jì)時(shí)器是否運(yùn)行中的狀態(tài)標(biāo)記
  private long elapsedNanos;//用于標(biāo)記從計(jì)時(shí)器開啟到調(diào)用統(tǒng)計(jì)的方法時(shí)過去的時(shí)間
  private long startTick;//計(jì)時(shí)器開啟的時(shí)刻時(shí)間
}

通過對elapsedNanos如叼、startTick結(jié)合當(dāng)前時(shí)刻時(shí)間冰木,可以計(jì)算出我們所需要的程序運(yùn)行流逝的時(shí)間長度。

首先來看Ticker工具類:

public static Stopwatch createStarted() {
    return new Stopwatch().start();
}

Stopwatch() {
    this.ticker = Ticker.systemTicker();
  }


private static final Ticker SYSTEM_TICKER =
      new Ticker() {
        @Override
        public long read() {
          //ticker工具類read方法笼恰,直接獲取機(jī)器的毫秒時(shí)間
          return Platform.systemNanoTime();
        }
      };


static long systemNanoTime() {
    return System.nanoTime();
  }

StopWatch的幾個(gè)關(guān)鍵方法:

public Stopwatch start() {
    checkState(!isRunning, "This stopwatch is already running.");
    isRunning = true;
    startTick = ticker.read();//設(shè)置startTick時(shí)間為stopwatch開始啟動的時(shí)刻時(shí)間
    return this;
  }
public Stopwatch stop() {
    long tick = ticker.read();
    checkState(isRunning, "This stopwatch is already stopped.");
    isRunning = false;
    //設(shè)置elapsedNanos時(shí)間為方法調(diào)用時(shí)間-stopwatch開啟時(shí)間+上次程序stopwatch的elapsedNanos歷史時(shí)間 
    elapsedNanos += tick - startTick;
    return this;
  }

public long elapsed(TimeUnit desiredUnit) {
    return desiredUnit.convert(elapsedNanos(), NANOSECONDS);
  }


private long elapsedNanos() {
    //如果stopwatch仍在運(yùn)行中踊沸,返回當(dāng)前時(shí)刻時(shí)間-stopwatch開啟時(shí)刻時(shí)間+歷史elapsedNanos時(shí)間(elapsedNanos只在stop和reset時(shí)會更新)
    //如果stopwatch已停止運(yùn)行,則直接返回elapsedNanos社证,詳見stop()
    return isRunning ? ticker.read() - startTick + elapsedNanos : elapsedNanos;
  }

結(jié)論

調(diào)用方式1:

Stopwatch stopwatch = Stopwatch.createStarted();
doSomething();
stopwatch.stop(); // optional
long millis = stopwatch.elapsed(MILLISECONDS);
log.info("time: " + stopwatch); // formatted string like "12.3 ms"

使用stopwatch對程序運(yùn)行時(shí)間進(jìn)行調(diào)試逼龟,首先調(diào)用StopWatch.createStarted()創(chuàng)建并啟動一個(gè)stopwatch實(shí)例,調(diào)用stopwatch.stop()停止計(jì)時(shí)追葡,此時(shí)會更新stopwatch的elapsedNanos時(shí)間腺律,為stopwatch開始啟動到結(jié)束計(jì)時(shí)的時(shí)間,再次調(diào)用stopwatch.elapsed()宜肉,獲取stopwatch在start-stop時(shí)間段匀钧,時(shí)間流逝的長度。

調(diào)用方式2:

Stopwatch stopwatch = Stopwatch.createStarted();
doSomething();
//stopwatch.stop();
long millis = stopwatch.elapsed(MILLISECONDS);
log.info("time: " + stopwatch); // formatted string like "12.3 ms"

createStarted啟動了一個(gè)stopwatch實(shí)例谬返,stopwatch的時(shí)間持續(xù)流逝之斯,調(diào)用elapsed方法,返回isRunning ? ticker.read() - startTick + elapsedNanos : elapsedNanos;遣铝,此時(shí)得到的返回值是當(dāng)前時(shí)間和stopwatch.start()時(shí)刻時(shí)間的時(shí)間差值佑刷,所以是一個(gè)持續(xù)遞增的時(shí)間。

如果需要在程序中對關(guān)鍵步驟的每一步進(jìn)行進(jìn)行持續(xù)度量酿炸,需要使用如下調(diào)用方式

Stopwatch stopwatch = Stopwatch.createStarted();
doSomething();
stopwatch.stop();
long millis = stopwatch.elapsed(MILLISECONDS);
log.info("time: " + stopwatch); // formatted string like "12.3 ms"

stopwatch.reset().start();
doSomething();
stopwatch.stop();
long millis = stopwatch.elapsed(MILLISECONDS);
log.info("time: " + stopwatch); // formatted string like "12.3 ms"
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瘫絮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子填硕,更是在濱河造成了極大的恐慌檀何,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件频鉴,死亡現(xiàn)場離奇詭異,居然都是意外死亡施敢,警方通過查閱死者的電腦和手機(jī)周荐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來骤素,“玉大人济竹,你說我怎么就攤上這事∠埃” “怎么了?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵捏肢,是天一觀的道長鸵赫。 經(jīng)常有香客問我,道長一睁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任瘤泪,我火速辦了婚禮,結(jié)果婚禮上实檀,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好侨颈,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布耘分。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪卜朗。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天泣港,我揣著相機(jī)與錄音呛每,去河邊找鬼。 笑死箫柳,一個(gè)胖子當(dāng)著我的面吹牛手形,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播悯恍,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼涮毫,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤唠粥,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后晤愧,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體大莫,經(jīng)...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡烙丛,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了羔味。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片河咽。...
    茶點(diǎn)故事閱讀 39,703評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖赋元,靈堂內(nèi)的尸體忽然破棺而出忘蟹,到底是詐尸還是另有隱情,我是刑警寧澤搁凸,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布媚值,位于F島的核電站,受9級特大地震影響护糖,放射性物質(zhì)發(fā)生泄漏褥芒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一椅文、第九天 我趴在偏房一處隱蔽的房頂上張望喂很。 院中可真熱鬧,春花似錦皆刺、人聲如沸少辣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽漓帅。三九已至,卻和暖如春痴怨,著一層夾襖步出監(jiān)牢的瞬間忙干,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工浪藻, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留捐迫,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓爱葵,卻偏偏與公主長得像施戴,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子萌丈,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評論 2 353

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,074評論 25 707
  • ¥開啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個(gè)線程赞哗,因...
    小菜c閱讀 6,401評論 0 17
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)辆雾,斷路器肪笋,智...
    卡卡羅2017閱讀 134,651評論 18 139
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法藤乙,繼承相關(guān)的語法猜揪,異常的語法,線程的語...
    子非魚_t_閱讀 31,622評論 18 399
  • 感賞自己今天在忘了調(diào)鬧鐘的情況下七點(diǎn)零五分準(zhǔn)時(shí)驚醒坛梁,雖然沒有時(shí)間煮早餐湿右,但也沒有遲到。感賞女兒的老師分享了女兒吃早...
    旦子閱讀 170評論 0 4