Android性能优化之APP 启动优化(不敢说秒开,但是最终优化完真不到 1s)

本文介绍了Android应用启动时的ActivityThread.main()流程,重点讨论了启动黑白屏问题的解决策略,包括使用不同的AppTheme、设置windowBackground以及在特定场景下的优化技巧,同时提供了测量和分析应用启动时间的方法。
摘要由CSDN通过智能技术生成

根据上面的动画,大家应该已经明白 ActivityThread.java main() 方法中 Appcation onCreate() 的是怎么被调用起来的吧。

注意:

不知道大家有没有注意 ActivityThread main() 中 Looper.prepareMainLooper(); 其实咱们为什么能够在 Main Thread 中创建 Handler 不会报错了吧,是因为 Activity 启动的时候在这里已经默认开启了 Looper。

APP 启动黑白屏问题


终于到了正题了,下面我们就来说下启动黑白屏的问题,还是先来看一个 GIF 吧。

市面上 APP 黑白屏

从上面的一段录屏我们可以发现市面上常见的 APP 启动有的是白屏有的是做了优化。黑屏只有在 Android 4.n 具体是哪个版本我也忘了。那么现在我们就以我现在的真实项目来优化一下启动。

真实项目中优化

简介

首先为什么会造成白屏勒我们来看一段源码

最后就是这个 windowBackground 搞的鬼,知道了是这个搞的鬼那么我们就可以来进行优化了。

优化方案 一

在自己的 AppTheme 中加入 windowBackground

优化方案 二

设置 windowbackgroud 为透明的

true

但是:

​ 这 2 中方法会有一个问题,就是所有的 Activity 启动都会显示。

优化方案 三

  1. 单独做成一个 AppTheme.Launcher
  1. 在清单文件中 启动 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”>

  1. 在启动 Activity 页面中加入

setTheme(R.style.AppTheme_Launcher);

最后这样做只有启动的 UI 才能见到自己的样式

  1. 最后效果,因为我这里没有背景图,故弄了一个主题颜色,如果想要设置一张背景图片可以参考下面的示例,不然有可能会引起图片拉伸效果。

我这里启动时间大概在 500 ms ~ 800 ms 左右。

<?xml version="1.0" encoding="utf-8"?>

<bitmap android:src=“@mipmap/app_bg”

android:gravity=“fill”/>

最后在清单 启动 Activity 的 Theme 中修改为

@drawable/app_theme_bg

  1. 据说 QQ 的实现方法是(这里只做参考,感兴趣的同学可以自己试试。)

true

@null

启动时间查看


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 、对异步要求不高

资源分享

  • 最新大厂面试专题

这个题库内容是比较多的,除了一些流行的热门技术面试题,如Kotlin,数据库,Java虚拟机面试题,数组,Framework ,混合跨平台开发,等

  • 对应导图的Android高级工程师进阶系统学习视频
    最近热门的,NDK,热修复,MVVM,源码等一系列系统学习视频都有!


《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
库内容是比较多的,除了一些流行的热门技术面试题,如Kotlin,数据库,Java虚拟机面试题,数组,Framework ,混合跨平台开发,等

[外链图片转存中…(img-P05lBOGT-1714739091480)]

  • 对应导图的Android高级工程师进阶系统学习视频
    最近热门的,NDK,热修复,MVVM,源码等一系列系统学习视频都有!

[外链图片转存中…(img-nHoeswK7-1714739091482)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 17
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值