ServiceTimeout 3,比较少出现的一种类型,原因是Service的各个生命周期函数在特定时间(20s)内无法完成处理。
=======================================================================
当发生ANR时,可以通过结合Logcat日志和生成的位于手机内部存储的/data/anr/traces.tex文件进行分析和定位。
==================================================================
Android系统每隔16ms发出VSYNC信号,触发对UI进行渲染,如果每次渲染都成功,就能够达到流畅的画面所需要的60fps。(为了能够实现60fps,这意味着程序的大多数操作都必须在16ms内完成) 如果你的某个操作花费时间是超过了16ms,系统在得到VSYNC信号的时候就无法进行正常渲染,这样就发生了丢帧现象。那么用户在当前帧看到的仍然是上一帧画面。
==============================================================================
原理简介:
1、卡顿发生在主线程,主线程的所有事件处理都是在主线程的looper中处理的
2、looper的loop方法中,在调用msg.target.dispatchMessage(msg);处理消息前后会使用printer打印message信息,
3、设置自定义的printer,第一次调用时记录开始时间T1,第二次调用时记录结束时间T2,对应消息处理前后的时间,如果两次时间差超过自定义的阻塞时间,则调出T1到T2的堆栈信息进行处理显示。
========================================================================
(1)界面布局较为复杂造成界面过度绘制(使用调试GPU过度绘制来查看界面)(背景)
进行布局优化
(2)动画太多或者动画执行过程较为复杂
简化动画;使用属性动画
(3)view绘制过程较为耗时(gpu呈现模式分析)
简化逻辑
(4)gc占用程序计算时间(Memory Monitor里面查看到短时间发生了多次内存的涨跌,这意味着很有可能发生了内存抖动,Allocation Tracker来查看在短时间内,同一个栈中不断进出的相同对象)
对象重复利用
(5)内存泄漏(内存泄漏指的是那些程序不再使用的对象无法被GC识别,这样就导致这个对象一直留在内存当中,占用了宝贵的内存空间。显然,这还使得每级Generation的内存区域可用空间变小,GC就会更容易被触发,间接导致卡顿问题)(leakcanary检测)
(6)列表优化,使用局部刷新
===========================================================================
-
第一章.ANR问题解析
-
第二章.crash监控方案
-
第三章.启动速度与执行效率优化项目实战
-
第四章.内存优化
-
第五章.耗电优化
-
第六章.网络传输与数据存储优化
-
第七章.apk大小优化
-
第八章.实战项目
最后
针对Android程序员,我这边给大家整理了一些资料,包括不限于高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter等全方面的Android进阶实践技术;希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!
-
Android前沿技术大纲
-
全套体系化高级架构视频
资料领取:点赞+点击GitHub免费获取
往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、混合式开发(ReactNative+Weex)全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。