您的位置:首页 > 移动开发

性能优化(一)APP 启动优化之启动黑白屏问题和检测总结

2019-09-18 20:01 453 查看
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接:https://blog.csdn.net/Aerfa789/article/details/100996062

下面我们就来说下启动黑白屏的问题,还是先来看一个 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 中优化方案

  1. 开子线程
    线程中没有创建 Handler、没有操作 UI 、对异步要求不高
  2. 懒加载
    用到的时候在初始化,如网络,数据库,图片库,或一些三方库。
  3. 使用 IntentService onHandleIntent () 方法来进行初始化一些比较耗时的操作

总结

最后启动优化可以配合上面的 3 点优化方案 + Appcation 优化方案 = 你自己最优方案

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: