「性能優(yōu)化1.1」計(jì)算方法的執(zhí)行時(shí)間

「性能優(yōu)化1.0」啟動(dòng)分類及啟動(dòng)時(shí)間的測(cè)量
「性能優(yōu)化1.1」計(jì)算方法的執(zhí)行時(shí)間

一忽肛、計(jì)算方法的執(zhí)行時(shí)間

我們?cè)谇懊娴膸灼┛椭蟹治隽巳绾潍@取應(yīng)用的啟動(dòng)時(shí)間,我們也知道啟動(dòng)過程中我們能優(yōu)化的方向就是 Application 和 Activity 的生命周期擒权,那么我們現(xiàn)在就來計(jì)算在啟動(dòng)過程 Application 中每一個(gè)調(diào)用每一個(gè)方法的執(zhí)行耗時(shí)。

1.1、常規(guī)方案

手動(dòng)埋點(diǎn)的方式鸵隧,這種方案就是跟我們埋點(diǎn)獲取應(yīng)用啟動(dòng)時(shí)間是一樣的原理,只要在方法執(zhí)行前和執(zhí)行后埋點(diǎn)财破,然后計(jì)算這兩個(gè)埋點(diǎn)的時(shí)間差值就是該方法執(zhí)行的耗時(shí)時(shí)間了掰派。

具體的埋點(diǎn)實(shí)現(xiàn)如下代碼所示,在 Application 中 onCreate 方法中調(diào)用了很多初始化的方法左痢,我們通過埋點(diǎn)的方式在每一個(gè)調(diào)用的方法內(nèi)部都去計(jì)算其方法的耗時(shí)時(shí)間靡羡。

//Application.java
@Override
public void onCreate() {
    initImageLoader();
    initBugly();
    initSharedPreference();
    //.....
}

private void initImageLoader() {
    long startTime = System.currentTimeMillis();
    Fresco.initialize(this);
    Log.d(TAG, "initImageLoader cost :" + (System.currentTimeMillis() - startTime));

private void initBugly() {
    long startTime = System.currentTimeMillis();
    //init bugly
    Log.d(TAG, "initBugly cost :" + (System.currentTimeMillis() - startTime));    
}

private void initSharedPreference() {
    long startTime = System.currentTimeMillis();
    //init SharedPreference
    Log.d(TAG, "initSharedPreference cost :" + (System.currentTimeMillis() - startTime));    
}

我們可以看到,以上這種方法是我們第一個(gè)想到的實(shí)現(xiàn)方式俊性,但是也是缺點(diǎn)也是很明顯:

  • 代碼很不優(yōu)雅略步,每一個(gè)方法都需要進(jìn)行埋點(diǎn)。
  • 對(duì)項(xiàng)目的侵入性很大定页,并且工作量也很大趟薄。

1.2、AOP方式來獲取

1.2.1典徊、基本概念

AOP 就是我們常說的面向切面編程杭煎,它可以針對(duì)同一類問題進(jìn)行統(tǒng)一處理

下面我們就來通過 AOP 的方式來優(yōu)雅的獲取Application每一個(gè)方法的執(zhí)行時(shí)間卒落。

1.2.2羡铲、引入 AspectJ

在 Android 中通過 AspectJ 這個(gè)庫(kù)來使用 AOP ,接下來來引入這個(gè)庫(kù):

  • 在工程根 build.gradle 中引入 AspectJ 插件

classpath 'com.hujiang.aspectjx:gradle-android-plugin-aspectjx:2.0.4'

  • 在 build.gradle 應(yīng)用插件

apply plugin: 'android-aspectjx'

  • 在 build.gradle 中引入 aspectj 庫(kù)

implementation 'org.aspectj:aspectjrt:1.8.9'

好了通過以上幾步儡毕,我們就快速的接入的 AspectJ 這個(gè)庫(kù)了也切。

1.2.3、具體使用

  • 定義一個(gè)類PerformanceAop使用@Aspect注解
  • @Around("execution(* com.example.perfermance.aop.MyApplication.**(..))")表示需要對(duì) MyApplication中的每一個(gè)方法都做 hook 處理腰湾。
  • 記錄方法執(zhí)行前后的時(shí)間戳雷恃,并計(jì)算對(duì)應(yīng)的時(shí)間差。

注意: 關(guān)于 AspectJ 詳細(xì)使用费坊,讀者可以去網(wǎng)上查閱資料倒槐,目前筆者只是實(shí)現(xiàn)計(jì)算方法的耗時(shí)計(jì)算,詳細(xì)的操作并沒有展開分析附井。

@Aspect
public class PerformanceAop {

    private static final String TAG = PerformanceAop.class.getSimpleName();

    @Around("execution(* com.example.perfermance.aop.MyApplication.**(..))")
    public void getTime(ProceedingJoinPoint joinPoint) {
        Signature signature = joinPoint.getSignature();
        //得到方法的名字导犹,例如:MyApplication.attachBaseContext(..)
        String name = signature.toShortString();
        //記錄方法執(zhí)行前的時(shí)間戳
        long startTime = System.currentTimeMillis();

        try {
            //執(zhí)行該方法
            joinPoint.proceed();
        } catch (Throwable throwable) {
            throwable.printStackTrace();
        }
        //記錄執(zhí)行該方法的時(shí)間
        long costTime = System.currentTimeMillis() - startTime;

        Log.e(TAG, "method " + name + " cost:" + costTime);
    }
}

程序運(yùn)行的結(jié)果:

2019-03-17 20:29:12.946 10094-10094/com.example.perfermance E/PerformanceAop: method MyApplication.attachBaseContext(..) cost:1
2019-03-17 20:29:12.979 10094-10094/com.example.perfermance E/PerformanceAop: method MyApplication.initBugly() cost:12
2019-03-17 20:29:13.002 10094-10094/com.example.perfermance E/PerformanceAop: method MyApplication.initImageLoader() cost:23
2019-03-17 20:29:13.002 10094-10094/com.example.perfermance E/PerformanceAop: method MyApplication.onCreate() cost:35

二唱凯、總結(jié)

我們?cè)诒酒恼轮饕菑某R?guī)的方式和 AOP 的方式來計(jì)算方法的耗時(shí)計(jì)算,而常規(guī)實(shí)現(xiàn)方案可以看出代碼很不優(yōu)雅谎痢,每一個(gè)方法都需要進(jìn)行埋點(diǎn)并且對(duì)項(xiàng)目的侵入性很大磕昼,工作量也很大。而 AOP 這種方式是一個(gè)比較優(yōu)雅的方式實(shí)現(xiàn)的节猿,它對(duì)已有代碼是零侵入性的票从,修改也方便。

記錄于 2019年3月17日

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末滨嘱,一起剝皮案震驚了整個(gè)濱河市峰鄙,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌太雨,老刑警劉巖吟榴,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異囊扳,居然都是意外死亡吩翻,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門锥咸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來狭瞎,“玉大人,你說我怎么就攤上這事搏予⌒芏В” “怎么了?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵雪侥,是天一觀的道長(zhǎng)碗殷。 經(jīng)常有香客問我,道長(zhǎng)速缨,這世上最難降的妖魔是什么亿扁? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮鸟廓,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘襟己。我一直安慰自己引谜,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布擎浴。 她就那樣靜靜地躺著员咽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪贮预。 梳的紋絲不亂的頭發(fā)上贝室,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天契讲,我揣著相機(jī)與錄音,去河邊找鬼滑频。 笑死捡偏,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的峡迷。 我是一名探鬼主播银伟,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼绘搞!你這毒婦竟也來了彤避?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤夯辖,失蹤者是張志新(化名)和其女友劉穎琉预,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蒿褂,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡圆米,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了贮缅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片榨咐。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖谴供,靈堂內(nèi)的尸體忽然破棺而出块茁,到底是詐尸還是另有隱情,我是刑警寧澤桂肌,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布数焊,位于F島的核電站,受9級(jí)特大地震影響崎场,放射性物質(zhì)發(fā)生泄漏佩耳。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一谭跨、第九天 我趴在偏房一處隱蔽的房頂上張望干厚。 院中可真熱鬧,春花似錦螃宙、人聲如沸蛮瞄。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)挂捅。三九已至,卻和暖如春堂湖,著一層夾襖步出監(jiān)牢的瞬間闲先,已是汗流浹背状土。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留伺糠,地道東北人蒙谓。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像退盯,于是被迫代替她去往敵國(guó)和親彼乌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345