android 性能分析(優(yōu)化)-利用AOP技術(shù),字節(jié)碼方法插樁百新,實(shí)現(xiàn) android 耗時(shí)統(tǒng)計(jì)

在android開發(fā)的過程中企软,不管是開發(fā)SDK還是開發(fā)App,我們時(shí)常有這么一個(gè)需求吟孙,性能優(yōu)化,或者卡頓優(yōu)化聚蝶,通常進(jìn)行這項(xiàng)工作的時(shí)候杰妓,我們可能會(huì)憑著主觀的一些觀點(diǎn),去定位排查某一部分代碼碘勉,常用的手段就是在可疑代碼前后加時(shí)間戳相減來(lái)手動(dòng)統(tǒng)計(jì)巷挥,或者在運(yùn)行的過程中,通過看android 自帶的性能分析工具來(lái)進(jìn)行優(yōu)化验靡。但這種方式難免會(huì)有疏漏倍宾,而且每段代碼的執(zhí)行過程也是不容易追蹤的。

今天就來(lái)給大家介紹一個(gè)胜嗓,利用AOP技術(shù)高职,字節(jié)碼編譯期方法插樁的方式,統(tǒng)計(jì)android耗時(shí)的工具辞州。

github地址:https://github.com/miqt/PluginTools

這是一個(gè)android 方法耗時(shí)統(tǒng)計(jì)打印插件怔锌,可以根據(jù)包名,類名,方法正則表達(dá)式等埃元,指定插入代碼進(jìn)行統(tǒng)計(jì)涝涤,在做性能調(diào)優(yōu)的時(shí)候非常方便。能清晰的觀察每個(gè)方法的耗時(shí)情況岛杀。另外還可以自定義統(tǒng)計(jì)實(shí)現(xiàn)類阔拳,增加額外的內(nèi)容。

[圖片上傳失敗...(image-93a384-1584524975350)][外鏈圖片轉(zhuǎn)存失敗,源站可能有防盜鏈機(jī)制,建議將圖片保存下來(lái)直接上傳(img-JP6etkK5-1584524741926)(https://api.bintray.com/packages/miqingtang/maven/pluginSrc/images/download.svg)]

效果展示:

統(tǒng)計(jì)項(xiàng)目中所有activity的方法耗時(shí)情況:

2020-03-18 16:09:11.540 23078-23078/? D/TimePrint:  
    ╔======================================================================================
    ║[Thread]:main
    ║[Method]:androidx.appcompat.app.AppCompatDelegateImpl.ensureSubDecor() type:void
    ║[Time]:84
    ╚======================================================================================
2020-03-18 16:09:11.575 23078-23078/? I/TimePrint:  
    ╔======================================================================================
    ║[Thread]:main
    ║[Method]:androidx.appcompat.app.AppCompatDelegateImpl.setContentView(int) type:void
    ║[Time]:118
    ╚======================================================================================
2020-03-18 16:09:11.575 23078-23078/? I/TimePrint:  
    ╔======================================================================================
    ║[Thread]:main
    ║[Method]:androidx.appcompat.app.AppCompatActivity.setContentView(int) type:void
    ║[Time]:118
    ╚======================================================================================
2020-03-18 16:09:11.575 23078-23078/? I/TimePrint:  
    ╔======================================================================================
    ║[Thread]:main
    ║[Method]:com.miqt.plugindemo.MainActivity.onCreate(android.os.Bundle) type:void
    ║[Time]:142
    ╚======================================================================================

可以看出类嗤,這樣的話方法名糊肠,運(yùn)行線程,和耗時(shí)情況就都一目了然啦土浸。

也支持注解指定固定的方法 @PrintTime:

@PrintTime
public static String getStr() {
    try {
        Thread.sleep(1000);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    return "hello";
}

使用方法:

項(xiàng)目根目錄:build.gradle 添加以下代碼

dependencies {
    classpath 'me.miqt.plugin.tools:pluginSrc:x.x.x'
}

對(duì)應(yīng) module 中啟用插件罪针,可以是application也可以是library

apply plugin: 'miqt.plugin.tools'

methodtimer {
    enable = true //是否啟用
    //項(xiàng)目中的class true:全部插樁 false:只有注解插樁
    all = true

    //指定插樁那些外部引用的jar,默認(rèn)空黄伊,表示只對(duì)項(xiàng)目中的class插樁
    jarRegexs = [".*androidx.*"]
    //指定插樁那些類文件泪酱,默認(rèn)空
    classRegexs = [".*view.*"]
    //所有包含 on 的方法,所有構(gòu)造方法
    methodRegexs = [".*on.*", ".*init.*"]
    
    //編譯時(shí)是否打印log
    log = true
    //是否用插樁后的jar包替換項(xiàng)目中的jar包,慎用
    replaceJar = false
    //是否生成詳細(xì)mapping文件
    mapping = true
    //自定義方法統(tǒng)計(jì)實(shí)現(xiàn)類,不指定默認(rèn)使用自帶實(shí)現(xiàn)方式
    //impl = "com.miqt.plugindemo.MyTimeP"
}

添加類庫(kù)依賴:

dependencies {
    implementation 'me.miqt.plugin.tools:pluginlib:x.x.x'
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末还最,一起剝皮案震驚了整個(gè)濱河市墓阀,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌拓轻,老刑警劉巖斯撮,帶你破解...
    沈念sama閱讀 216,470評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異扶叉,居然都是意外死亡勿锅,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門枣氧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)溢十,“玉大人,你說(shuō)我怎么就攤上這事达吞≌懦冢” “怎么了?”我有些...
    開封第一講書人閱讀 162,577評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵酪劫,是天一觀的道長(zhǎng)吞鸭。 經(jīng)常有香客問我,道長(zhǎng)覆糟,這世上最難降的妖魔是什么刻剥? 我笑而不...
    開封第一講書人閱讀 58,176評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮滩字,結(jié)果婚禮上透敌,老公的妹妹穿的比我還像新娘盯滚。我一直安慰自己,他們只是感情好酗电,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評(píng)論 6 388
  • 文/花漫 我一把揭開白布魄藕。 她就那樣靜靜地躺著,像睡著了一般撵术。 火紅的嫁衣襯著肌膚如雪背率。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,155評(píng)論 1 299
  • 那天嫩与,我揣著相機(jī)與錄音寝姿,去河邊找鬼。 笑死划滋,一個(gè)胖子當(dāng)著我的面吹牛饵筑,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播处坪,決...
    沈念sama閱讀 40,041評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼根资,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了同窘?” 一聲冷哼從身側(cè)響起玄帕,我...
    開封第一講書人閱讀 38,903評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎想邦,沒想到半個(gè)月后裤纹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,319評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡丧没,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評(píng)論 2 332
  • 正文 我和宋清朗相戀三年鹰椒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片呕童。...
    茶點(diǎn)故事閱讀 39,703評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡漆际,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出拉庵,到底是詐尸還是另有隱情灿椅,我是刑警寧澤套蒂,帶...
    沈念sama閱讀 35,417評(píng)論 5 343
  • 正文 年R本政府宣布钞支,位于F島的核電站,受9級(jí)特大地震影響操刀,放射性物質(zhì)發(fā)生泄漏烁挟。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評(píng)論 3 325
  • 文/蒙蒙 一骨坑、第九天 我趴在偏房一處隱蔽的房頂上張望撼嗓。 院中可真熱鬧柬采,春花似錦、人聲如沸且警。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)斑芜。三九已至肩刃,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間杏头,已是汗流浹背盈包。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留醇王,地道東北人呢燥。 一個(gè)月前我還...
    沈念sama閱讀 47,711評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像寓娩,于是被迫代替她去往敵國(guó)和親叛氨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評(píng)論 2 353

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

  • 我們產(chǎn)線的主流程頁(yè)面中有幾個(gè)比較復(fù)雜的頁(yè)面在版本迭代中流暢度頻繁出現(xiàn)反復(fù)根暑,經(jīng)常由于開發(fā)的不注意導(dǎo)致變卡力试,主要是對(duì)流...
    舒大飛閱讀 1,296評(píng)論 0 11
  • 自己總結(jié)的Android開源項(xiàng)目及庫(kù)。 github排名https://github.com/trending,g...
    passiontim閱讀 2,538評(píng)論 1 26
  • 說(shuō)到 Android 系統(tǒng)手機(jī)排嫌,大部分人的印象是用了一段時(shí)間就變得有點(diǎn)卡頓畸裳,有些程序在運(yùn)行期間莫名其妙的出現(xiàn)崩潰,...
    cowboy3000閱讀 597評(píng)論 0 2
  • 91年的我從事幫別人看病已經(jīng)有5個(gè)年頭了淳地!我從小在一個(gè)有著濃郁中醫(yī)氛圍的環(huán)境中長(zhǎng)大怖糊!每天看著爺爺診所進(jìn)進(jìn)出出的病人...
    丁藥童閱讀 844評(píng)論 0 2
  • 今天時(shí)不時(shí)會(huì)有小雨.還在擔(dān)心今晚夜跑會(huì)取消.在開跑前.大家的熱情早已經(jīng)融化了雨.7:30集結(jié)完畢.在工作室熱好身就...
    晨曦山雞閱讀 186評(píng)論 0 0