性能优化(一)APP 启动优化之启动黑白屏问题和检测总结
下面我们就来说下启动黑白屏的问题,还是先来看一个 GIF 吧
市面上 APP 黑白屏
从上面的一段录屏我们可以发现市面上常见的 APP 启动有的是白屏有的是做了优化。黑屏只有在 Android 4.n 具体是哪个版本我也忘了。那么现在我们就以我现在的真实项目来优化一下启动。
真实项目中优化
简介
首先为什么会造成白屏勒我们来看一段源码
最后就是这个 windowBackground 搞的鬼,知道了是这个搞的鬼那么我们就可以来进行优化了
优化方案 一
在自己的 AppTheme 中加入 windowBackground
优化方案 二
设置 windowbackgroud 为透明的
<item name="android:windowIsTranslucent">true</item>
但是:
这 2 中方法会有一个问题,就是所有的 Activity 启动都会显示
优化方案 三
1.单独做成一个 AppTheme.Launcher
<style name="AppTheme.Launcher"> <item name="android:windowFullscreen">true</item> <!--<item name="android:windowDisablePreview">true</item>--> <item name="android:windowBackground">@color/colorAccent</item> </style>
2.在清单文件中 启动 Activity 加入该 主题
<activity android:name="com.t01.android.dida_login.mvp.ui.activity.LoginActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:theme="@style/AppTheme.Launcher" android:windowSoftInputMode="adjustUnspecified|stateHidden"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity>
3.在启动 Activity 页面中加入
setTheme(R.style.AppTheme_Launcher);
最后这样做只有启动的 UI 才能见到自己的样式
4.最后效果,因为我这里没有背景图,故弄了一个主题颜色,如果想要设置一张背景图片可以参考下面的示例,不然有可能会引起图片拉伸效果。
我这里启动时间大概在 500 ms ~ 800 ms 左右
<?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android="http://schemas.android.com/apk/res/android"> <item> <bitmap android:src="@mipmap/app_bg" android:gravity="fill"/> </item> </layer-list>
最后在清单 启动 Activity 的 Theme 中修改为
<item name="android:windowBackground">@drawable/app_theme_bg</item>
5.据说 QQ 的实现方法是(这里只做参考,感兴趣的同学可以自己试试。)
<item name="android:windowDisablePreview">true</item> <item name="android:windowBackground">@null</item>
启动时间查看
4.4 以前版本查看
adb shell am start -W packName/activity 全路径
4.4 版本以后查看方式
通过关键字 Displayed 并筛选为 No Filters
2019-04-25 18:35:57.629 508-629/? I/ActivityManager: Displayed com.lingyi.autiovideo.lykj/com.t01.android.dida_login.mvp.ui.activity.LoginActivity: +844ms
工具分析代码执行
Appcation 中查看耗时通过(如果有的同学还用 Log 打印系统时间来相减来查看 耗时的话,看完我这篇文章就可以换成下面方法了,不然就有点 LOW 了哈)
//开始计时 Debug.startMethodTracing(filePath); 中间为需要统计执行时间的代码 //停止计时 Debug.stopMethodTracing();
还是通过一组动画来看我怎么操作的吧。(注意这里的时间是 微妙 微妙/10^6 = s 应该是这样,忘了)
这个工具可以很友好的提示每个函数具体在内部执行了多少时间,卡顿其实也可以用这个方法来进行监测
导出 trace 文件命令
adb pull /storage/emulated/0/appcation_launcher_time.trace
我这里耗时还不算太大 大概在 0.2 - 0.3 s 左右。
Appcation 中优化方案
- 开子线程
线程中没有创建 Handler、没有操作 UI 、对异步要求不高 - 懒加载
用到的时候在初始化,如网络,数据库,图片库,或一些三方库。 - 使用 IntentService onHandleIntent () 方法来进行初始化一些比较耗时的操作
总结
最后启动优化可以配合上面的 3 点优化方案 + Appcation 优化方案 = 你自己最优方案
- Android性能优化第(八)篇---App启动速度优化之耗时检测处理
- 性能优化-Android中APP冷启动黑白屏原因解密和实现秒开方案
- Android性能优化第(八)篇---App启动速度优化之耗时检测处理
- WP7 App性能优化(12):检测应用程序性能(Ⅴ)
- iOS App 性能优化总结
- Android APP性能优化的四个方面最全总结
- 标题: 优化 Java 垃圾收集的性能——如何利用 IBM Java 虚拟机检测和解决垃圾收集问题
- Android App 性能优化总结
- Android性能优化(一)App启动原理分析及启动时间优化
- sam 百度面经的问题总结(2) 性能优化
- 【转载】iOS App 性能优化总结
- Android性能优化系列之App启动优化
- Android性能优化系列之App启动优化
- Android 性能优化---(8)APP启动时间优化指南
- Android性能优化之App应用启动分析与优化
- iOS App性能优化之启动时间、内存
- Android的multidex带来的性能问题-减慢app启动速度
- Android--app启动 黑白屏问题 解决
- Android APP启动黑白屏问题解决方案
- Android性能优化(二):APP启动优化