APP启动的时候会有一个短暂的白屏现象
产生的原因是在application的默认主题style/AppTheme的父主题中设置windowBackground为白色
<style name="Platform.AppCompat.Light" parent="android:Theme.Holo.Light">
<item name="android:windowBackground">@color/background_material_light</item>
</style>
方法一:给白屏加一个图片
在AndroidManifest.xml中application的style添加一个背景图替代这个白屏或者在MainActivity的style中添加这个背景图
<item name="android:windowBackground">@drawable/guide_window_background</item>
方法二:
在MainActivity的style里面设置窗口是透明
<item name="android:windowIsTranslucent">true</item>
或者设置禁用窗口的预览动画
<item name="android:windowDisablePreview">true</item>
这两个都会有点击APP图标短暂延迟打开APP的现象。
查看activity的启动时长
adb shell am start -W [PackageName]/[PackageName.MainActivity] //W大写

- ThisTime:代表当前activity(就是这个Splash)启动时长,一般和TotalTime时间一样,除非中间有多个activity的启动,这样TotalTime就会比ThisTime长。
- TotalTime:应用的启动时间,包括创建进程+Application初始化+Activity初始化到界面显示。
- WaitTime:一般比TotalTime大点,包括系统影响的耗时。

需要在AndroidManifest中给activity添加一个属性
android:exported="true"
Trace 分析耗时
如果要分析一个方法的的耗时情况,先要生成对应的trace文件,如分析下面的initNim()方法。
File file = new File(Environment.getExternalStorageDirectory(),"app");
Debug.startMethodTracing(file.getAbsolutePath());
initNim();
Debug.stopMethodTracing();
运行完项目SD卡中就会有个app.trace的文件,把文件拖入android studio中显示。

- 黄色线方法执行的时长
- Top Down 至上而下的查看
-
Buttom Up 至下而上的查看
- total总耗时
- Children 子方法耗时
- Incl Real Time
某函数运行的真实时间(以毫秒为单位),内含调用其它函数所占用的真实时间 - Excl Real Time
某函数运行的真实时间(以毫秒为单位),不含调用其它函数所占用的真实时间 - Call+Recur Calls/Total
没展开某个方法时:会显示该方法被程序员主动调用次数,以及被自身递归调用次数;例如:2+3,程序员调用两次,自己递归调用3次。
展开某个方法时:父方法会显示:其调用(程序员主动调用,非递归)该方法的次数/该方法的总次数,例如:2/5,说明该方法总共被调用5次其中父方法主动调了他2次子方法会显示:子方法被其调用(程序员主动调用)的次数/子方法被调用的总次数,例如1/5
不要再Application类的onCreate中初始化一些第三方,如网络框架,图片加载框架等等,更不能做一些文件的操作,否则APP启动会很慢。
如果一定要在这里做一些初始化的操作,可以使用子线程。
最好是写个util,用懒汉式单例,第一次使用的时候会慢点。
网友评论