日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

一分鐘快速定位Android啟動耗時(shí)問題

瀏覽:62日期:2022-09-17 15:58:59
目錄前言1. 接入Tencent Matrix2. 改造Application子類3.運(yùn)行,快速定位總結(jié)前言

Tencent Matrix默認(rèn)無法監(jiān)測Application冷啟動的耗時(shí)方法,本文介紹了如何改造Matrix支持冷啟動耗時(shí)方法監(jiān)測。讓你一分鐘就能給App啟動卡頓號脈。

1. 接入Tencent Matrix

1.1 在你項(xiàng)目根目錄下的 gradle.properties 中配置要依賴的 Matrix 版本號,如:

MATRIX_VERSION=1.0.0

1.2 在你項(xiàng)目根目錄下的 build.gradle 文件添加 Matrix 依賴,如:

dependencies { classpath ('com.tencent.matrix:matrix-gradle-plugin:${MATRIX_VERSION}') { changing = true } }

1.3 在 app/build.gradle 文件中添加 Matrix 各模塊的依賴,如:

dependencies { implementation group: 'com.tencent.matrix', name: 'matrix-android-lib', version: MATRIX_VERSION, changing: true implementation group: 'com.tencent.matrix', name: 'matrix-android-commons', version: MATRIX_VERSION, changing: true implementation group: 'com.tencent.matrix', name: 'matrix-trace-canary', version: MATRIX_VERSION, changing: true implementation group: 'com.tencent.matrix', name: 'matrix-resource-canary-android', version: MATRIX_VERSION, changing: true implementation group: 'com.tencent.matrix', name: 'matrix-resource-canary-common', version: MATRIX_VERSION, changing: true implementation group: 'com.tencent.matrix', name: 'matrix-io-canary', version: MATRIX_VERSION, changing: true implementation group: 'com.tencent.matrix', name: 'matrix-sqlite-lint-android-sdk', version: MATRIX_VERSION, changing: true implementation group: 'com.tencent.matrix', name: 'matrix-battery-canary', version: MATRIX_VERSION, changing: true implementation group: 'com.tencent.matrix', name: 'matrix-hooks', version: MATRIX_VERSION, changing: true } apply plugin: ’com.tencent.matrix-plugin’ matrix { trace {enable = true//if you don’t want to use trace canary, set falsebaseMethodMapFile = '${project.buildDir}/matrix_output/Debug.methodmap'blackListFile = '${project.projectDir}/matrixTrace/blackMethodList.txt' } }

1.4 實(shí)現(xiàn) PluginListener,接收 Matrix 處理后的數(shù)據(jù), 如:

class MatrixListener(context: Context?) : DefaultPluginListener(context) { companion object {const val TAG: String = 'Matrix.TestPluginListener' } override fun onReportIssue(issue: Issue) {super.onReportIssue(issue)MatrixLog.e(TAG, issue.toString()) }}

1.5 實(shí)現(xiàn)動態(tài)配置接口, 可修改 Matrix 內(nèi)部參數(shù). 在 sample-android 中 我們有個(gè)簡單的動態(tài)接口實(shí)例DynamicConfigImplDemo.java, 其中參數(shù)對應(yīng)的 key 位于文件 MatrixEnum中, 摘抄部分示例如下:

class MatrixConfig : IDynamicConfig { val isFPSEnable: Booleanget() = true val isTraceEnable: Booleanget() = true val isMatrixEnable: Booleanget() = true override fun get(key: String, defStr: String): String {// for Activity leak detectif (ExptEnum.clicfg_matrix_resource_detect_interval_millis.name == key || ExptEnum.clicfg_matrix_resource_detect_interval_millis_bg.name == key) { Log.d('DynamicConfig','Matrix.ActivityRefWatcher: clicfg_matrix_resource_detect_interval_millis 10s' ) return TimeUnit.SECONDS.toMillis(5).toString()}if (ExptEnum.clicfg_matrix_resource_max_detect_times.name == key) { Log.d('DynamicConfig','Matrix.ActivityRefWatcher: clicfg_matrix_resource_max_detect_times 5' ) return 3.toString()}return defStr } override fun get(key: String, defInt: Int): Int {//TODO here return default value which is inside sdk, you can change it as you wish. matrix-sdk-key in class MatrixEnum.if (MatrixEnum.clicfg_matrix_resource_max_detect_times.name == key) { MatrixLog.i(TAG, 'key:$key, before change:$defInt, after change, value:2') return 2 //new value}if (MatrixEnum.clicfg_matrix_trace_fps_report_threshold.name == key) { return 10000}if (MatrixEnum.clicfg_matrix_trace_fps_time_slice.name == key) { return 12000}if (ExptEnum.clicfg_matrix_trace_app_start_up_threshold.name == key) { return 3000}return if (ExptEnum.clicfg_matrix_trace_evil_method_threshold.name == key) { 200} else defInt } override fun get(key: String, defLong: Long): Long {//TODO here return default value which is inside sdk, you can change it as you wish. matrix-sdk-key in class MatrixEnum.if (MatrixEnum.clicfg_matrix_trace_fps_report_threshold.name == key) { return 10000L}if (MatrixEnum.clicfg_matrix_resource_detect_interval_millis.name == key) { MatrixLog.i(TAG, '$key, before change:$defLong, after change, value:2000') return 2000}return defLong } override fun get(key: String, defBool: Boolean): Boolean {//TODO here return default value which is inside sdk, you can change it as you wish. matrix-sdk-key in class MatrixEnum.return defBool } override fun get(key: String, defFloat: Float): Float {//TODO here return default value which is inside sdk, you can change it as you wish. matrix-sdk-key in class MatrixEnum.return defFloat } companion object {private const val TAG = 'Matrix.DynamicConfigImplDemo' }}

1.6 選擇程序啟動的位置對 Matrix 進(jìn)行初始化,如在 Application 的繼承類中, Init 核心邏輯如下:

Matrix.Builder builder = new Matrix.Builder(application); // build matrix builder.patchListener(new TestPluginListener(this)); // add general pluginListener DynamicConfigImplDemo dynamicConfig = new DynamicConfigImplDemo(); // dynamic config // init plugin IOCanaryPlugin ioCanaryPlugin = new IOCanaryPlugin(new IOConfig.Builder() .dynamicConfig(dynamicConfig) .build()); //add to matrix builder.plugin(ioCanaryPlugin); //init matrix Matrix.init(builder.build()); // start plugin ioCanaryPlugin.start();2. 改造Application子類

2.1 模擬Application卡頓

private fun A() {B()H()L()SystemClock.sleep(800) } private fun B() {C()G()SystemClock.sleep(200) } private fun C() {D()E()F()SystemClock.sleep(100) } private fun D() {SystemClock.sleep(20) } private fun E() {SystemClock.sleep(20) } private fun F() {SystemClock.sleep(20) } private fun G() {SystemClock.sleep(20) } private fun H() {SystemClock.sleep(20)I()J()K() } private fun I() {SystemClock.sleep(20) } private fun J() {SystemClock.sleep(6) } private fun K() {SystemClock.sleep(10) } private fun L() {SystemClock.sleep(10000) }

2.2 Application.onCreate()調(diào)用卡頓方法

override fun onCreate() { A()}

2.3 反射獲取ActivityThread的mHandler

override fun attachBaseContext(base: Context?) { super.attachBaseContext(base) println('zijiexiaozhan MyApp attachBaseContext') time1 = SystemClock.uptimeMillis() time3 = System.currentTimeMillis() try { val forName = Class.forName('android.app.ActivityThread') val field = forName.getDeclaredField('sCurrentActivityThread') field.isAccessible = true val activityThreadValue = field[forName] val mH = forName.getDeclaredField('mH') mH.isAccessible = true val handler = mH[activityThreadValue] mHandler = handler as Handler } catch (e: Exception) { }}

2.4 將原來的onCreate的方法調(diào)用轉(zhuǎn)入匿名內(nèi)部類調(diào)用

inner class ApplicationTask : Runnable { override fun run() {A() }}

2.5 重寫Application onCreate方法

override fun onCreate() { super.onCreate() //重點(diǎn) mHandler.postAtFrontOfQueue(ApplicationTask())}3.運(yùn)行,快速定位

3.1 關(guān)鍵字'Trace_EvilMethod'查找日志

tag[Trace_EvilMethod]type[0];key[null];content[{'machine':'MIDDLE','cpu_app':0,'mem':3822452736,'mem_free':1164132,'detail':'NORMAL','cost':1344,'usage':'0.37%','scene':'default','stack':'0,1048574,1,1344n1,5471,1,1338n2,17582,1,1338n3,17558,1,1338n4,17560,1,379n5,17562,1,160n6,17563,1,17n6,17566,1,20n6,17568,1,20n5,17569,1,20n4,17573,1,56n5,17575,1,21n5,17576,1,5n5,17578,1,10n4,17580,1,102n','stackKey':'17558|','tag':'Trace_EvilMethod','process':'com.peter.viewgrouptutorial','time':1624837969986}]

3.2 解析日志 打印卡頓堆棧

android.os.Handler dispatchMessage 1344.com.peter.viewgrouptutorial.MyApp$ApplicationTask run 1338..com.peter.viewgrouptutorial.MyApp access$A 1338...com.peter.viewgrouptutorial.MyApp A 1338....com.peter.viewgrouptutorial.MyApp B 379.....com.peter.viewgrouptutorial.MyApp C 160......com.peter.viewgrouptutorial.MyApp D 17......com.peter.viewgrouptutorial.MyApp E 20......com.peter.viewgrouptutorial.MyApp F 20.....com.peter.viewgrouptutorial.MyApp G 20....com.peter.viewgrouptutorial.MyApp H 56.....com.peter.viewgrouptutorial.MyApp I 21.....com.peter.viewgrouptutorial.MyApp J 5.....com.peter.viewgrouptutorial.MyApp K 10....com.peter.viewgrouptutorial.MyApp L 102

總結(jié)

到此這篇關(guān)于快速定位Android啟動耗時(shí)問題的文章就介紹到這了,更多相關(guān)定位Android啟動耗時(shí)內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Android
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精品电影| 婷婷亚洲五月| 久久精品官网| 国产精品激情| 日韩一二三区在线观看| 日韩高清中文字幕一区二区| 欧美在线看片| 日韩一区欧美二区| 日韩亚洲在线| 日韩国产一区二| 91福利精品在线观看| 国产乱码精品一区二区三区亚洲人| 日韩中文字幕在线一区| 亚洲精品成人一区| 日韩高清中文字幕一区二区| 亚洲黄色免费av| 国产精品777777在线播放 | 日本不卡一区二区| 久久亚洲图片| 日本一区二区中文字幕| 老司机免费视频一区二区三区| 精品入口麻豆88视频| 伊人久久大香线蕉av不卡| 亚洲午夜电影| 日韩影片在线观看| 中文字幕日韩欧美精品高清在线| 亚洲精品伊人| 欧美日韩va| 视频福利一区| 亚洲中字黄色| 国产精品2区| 国产亚洲网站| 国产精品videossex久久发布 | 136国产福利精品导航网址| 四虎国产精品免费观看| 夜久久久久久| 日本在线视频一区二区| 国产精品调教| 狠狠色狠狠色综合日日tαg| 日韩成人一级| 久久精品主播| 亚洲一区av| 久久精品国产亚洲夜色av网站 | 九九久久电影| 国产精品二区影院| 蜜臀久久99精品久久久画质超高清 | 日韩在线精品| 国产亚洲亚洲| 日韩国产激情| 麻豆精品在线观看| 日本一区中文字幕| 亚洲二区三区不卡| 高清久久一区| 久久激情综合网| 99精品在线免费在线观看| 久久国产生活片100| 亚洲深爱激情| 久久久久美女| 日韩成人亚洲| av资源中文在线天堂| 国产精品mm| 97精品久久| 亚洲一区二区免费在线观看| 久久久噜噜噜| 日韩欧美字幕| 四虎影视精品| 国产在线欧美| 好看的av在线不卡观看| 日韩国产欧美| 日本免费一区二区三区四区| 国产精品成人一区二区不卡| 久久亚州av| 久久久久久婷| 97精品国产一区二区三区| 久久三级中文| 99精品在线观看| 石原莉奈在线亚洲三区| 亚洲精品看片| 国产美女精品视频免费播放软件| 国产精品久久久久久久久久妞妞| 国产欧美日韩一级| 国产精品2023| 91精品精品| 亚洲我射av| 欧美日一区二区三区在线观看国产免| 国产欧美日韩影院| 久久久久久黄| 精品欠久久久中文字幕加勒比| 麻豆精品久久久| 日韩大片在线| 蜜桃传媒麻豆第一区在线观看| 久久国产精品久久w女人spa| 天堂va欧美ⅴa亚洲va一国产| 日本成人一区二区| 久久精品系列| 亚洲激精日韩激精欧美精品| 日本三级亚洲精品| 久久久久久色 | 国产亚洲毛片| 麻豆一区二区三区| 麻豆久久精品| 中文在线免费视频| 日韩中文字幕亚洲一区二区va在线 | 美女黄网久久| 欧美成人a交片免费看| 中文字幕中文字幕精品| 亚洲1区在线观看| 国产91在线播放精品| 欧美一区在线观看视频| а√天堂8资源在线| 另类激情亚洲| 精品亚洲精品| 国产福利资源一区| 中文字幕日本一区| 免费高潮视频95在线观看网站| 国产精品黄色片| 中文字幕免费一区二区| 亚洲欧美不卡| 美女少妇全过程你懂的久久| 久久成人福利| 国产精品香蕉| 999久久久免费精品国产| 国产日韩一区| 日韩av一区二| 久久人人97超碰国产公开结果| 国产剧情在线观看一区| 国产精品扒开腿做爽爽爽软件| 日本成人中文字幕| 欧美不卡高清| 伊人久久成人| 最新日韩欧美| 黄毛片在线观看| 人人草在线视频| 色天使综合视频| 麻豆精品视频在线观看免费| 黑森林国产精品av| 欧美日韩精品免费观看视完整| 精品成人18| 色婷婷亚洲mv天堂mv在影片| 一区二区亚洲视频| 国产精品自拍区| 国产一区二区亚洲| 成人国产综合| 婷婷综合一区| 麻豆精品蜜桃视频网站| 久久97视频| 国产精品13p| 女生影院久久| 蜜桃传媒麻豆第一区在线观看| 日本91福利区| 精品久久久网| 蜜臀av一区二区三区| 免费精品一区| se01亚洲视频 | 免费不卡中文字幕在线| 亚久久调教视频| 国产精品久久久一区二区| 欧美99久久| 欧美片第1页综合| 久久亚洲精品中文字幕蜜潮电影| 国产精品嫩草99av在线| 亚洲精品观看| 香蕉精品视频在线观看| 欧美日一区二区在线观看| 成人污污视频| av亚洲免费| 青草国产精品久久久久久| 激情久久一区二区| 一区二区三区国产盗摄| 国产一区清纯| 国产日韩一区二区三免费高清| 日韩欧美一区二区三区免费看| 激情综合自拍| 偷拍精品精品一区二区三区| 国产精品s色| 欧美一区=区| 在线看片一区| 红桃视频欧美| 久久国产亚洲| 免费观看亚洲| 国产欧美二区| 国产欧美一区二区色老头| 丝袜亚洲精品中文字幕一区| 日韩在线免费| 美女精品久久| 日韩免费精品| 蜜臀a∨国产成人精品| 激情婷婷久久| 色综合www| 国产毛片精品| 日韩国产在线观看一区| 一区二区高清| 在线午夜精品| 日韩一级欧洲| 亚洲成人国产| 桃色一区二区| 99精品视频在线| 亚洲一卡久久| 午夜亚洲福利| 噜噜噜躁狠狠躁狠狠精品视频|