1Android绘制原理及工具选择
绘制原理
CPU负责计算显示内容
GPU负责柵格化(UI元素绘制到屏幕上)
系统每16ms发出VSync信号出发UI渲染(每帧在16ms内完成)
大多数Android手机屏幕刷新频率60Hz(人眼和大脑极限)
优化工具
1、Systrace --之前用它查看了内存消耗情况;现在关注Frames
正常:绿色原点,丢帧:黄色或者红色
Alerts栏
data:image/s3,"s3://crabby-images/bed72/bed729b4cee9c16f26c18e1d94caa214a8a6abf1" alt=""
2、Layout Inspector
AS自带
可查看层次结构
data:image/s3,"s3://crabby-images/f4003/f4003fcb2ac7a4b637e28eaa79d28084e2610d1e" alt=""
data:image/s3,"s3://crabby-images/49ff0/49ff03502bfb886a6149710415c0dbd65c36df79" alt=""
3、Choreographer
获取FPS,线上使用,具备实时性
API16+
Choreographer.getInstance().postFrameCallback
实际效果
data:image/s3,"s3://crabby-images/eafff/eafff29d089b2db273a460df63198e79297c5b85" alt=""
2Android布局加载原理
data:image/s3,"s3://crabby-images/f8570/f8570fb6f7ca2dbf57029559d01da08c4b0dd9ab" alt=""
性能瓶颈
布局文件解析:IO过程
创建View对象:反射过程
LayoutInflater.Factory介绍
LayoutInflater.创建View的一个Hook
定制创建View的过程:全局替换自定义的TextView等。
data:image/s3,"s3://crabby-images/78108/7810878431f09062f02f05f3bd761f11922c5aac" alt=""
data:image/s3,"s3://crabby-images/e3021/e3021e964494a5d2a72a9e9cb11440d712453d34" alt=""
Facory2多了一个parent参数
data:image/s3,"s3://crabby-images/55392/55392c65de23ec9a07b91f91f5867b591880152b" alt=""
Factory是Hook点
3优雅获取界面布局耗时
常规方式
背景:获取每个界面加载耗时
实现:复写SetContentView 手动埋点
不够优雅
有侵入性
AOP/ArtHook方式
AOP实现
切Activity的setContentView
data:image/s3,"s3://crabby-images/dd446/dd4460232e6219fb02c81562c95cf0ba25075693" alt=""
data:image/s3,"s3://crabby-images/d830c/d830c71fbb445bfabb0f8c3a30a7e99231efc0c5" alt=""
data:image/s3,"s3://crabby-images/f80d5/f80d5ecbb1fd00e8d8ec4be0225cfad66b66b45b" alt=""
第一个224ms 第二个10ms
ArtHook方式 略
切Activity的setContentView
获取任意控件耗时
低侵入性
用到LayoutInflater.Factory是创建View的一个hook
代码:
data:image/s3,"s3://crabby-images/b1d84/b1d841236a0b7ef545a8d17757ccc3feb9ae50b4" alt=""
data:image/s3,"s3://crabby-images/e34d9/e34d9015a54f888230f3a43fb0fe80bb1d6ebb17" alt=""
data:image/s3,"s3://crabby-images/78c32/78c32311e9a8e74dfd2ced49f56fc065ddd2cce5" alt=""
上图创建View 其实是系统hoot 创建了TextViewCompat 实现了兼容
注意:LayoutInflaterCompat要在super.onCreate(..)之前设置!!之后无效
4异步Inflate实战
背景介绍
布局文件解析慢:IO过程
创建View对象:反射过程(比new 慢3倍)
侧面缓解AsyncLayoutInflater实战
简称异步Inflate
1WorkThread加载布局
2回调主线程
3节约主线程时间
先导包:谷歌默认的但并没加载到里面
com.android.support:asynclayoutinflater
data:image/s3,"s3://crabby-images/c5e20/c5e20822510697d861c282709919bfe0a02e6dfe" alt=""
创建了一个Handler,一个线程。创建过程都在子线程。
使用AsyncLayoutInflater将会失去系统兼容效果!!要自己写。
总结
侧面缓解
data:image/s3,"s3://crabby-images/de4f1/de4f1c61202251c85aff3576f987e59d456316ac" alt=""
5布局加载优化实战
背景介绍
IO操作、反射
AsyncLayoutInflater只是缓解
data:image/s3,"s3://crabby-images/36ae0/36ae03e11de1a60102fa83a5167e9c8e7c765565" alt=""
布局加载优化实战
data:image/s3,"s3://crabby-images/f55e3/f55e3a63294f6d169540cbb313ec63d69350e80a" alt=""
data:image/s3,"s3://crabby-images/4b6b7/4b6b73f8044621f91489ce46d1ced99438285706" alt=""
data:image/s3,"s3://crabby-images/e3cfe/e3cfe3274a554accc130c78f3e65c91c87a14c73" alt=""
data:image/s3,"s3://crabby-images/38fb5/38fb561306d584e57a7922f8bfdafa39e87d73b5" alt=""
data:image/s3,"s3://crabby-images/9e848/9e848bc394a2c6d1aae13d3db5186da783eaec78" alt=""
data:image/s3,"s3://crabby-images/72a17/72a17b241cf6306ab36a0f280ccf62bc41c5e524" alt=""
6视图绘制优化实战
测量:确定大小
布局:确定位置
绘制:绘制视图
性能瓶颈
每个阶段都耗时
自顶向下的遍历
触发多次
优化布局层级及复杂度
准则
1减少View树层级
2宽而浅,避免窄而深
1、ConstraintLayout
实现几乎完全扁平化的布局
构建复杂布局性能更高
具有Relative和LinearLayout的特性
2、不嵌套使用RelativeLayout
3、不在嵌套的LinearLayout中使用weight
4、merge标签:减少一个层级,只能用于根View
避免过度绘制
一个像素最好只被绘制一次
调试GPU过度绘制
蓝色可接受(绿色粉色红色)
1去掉多余背景色,减少复杂shape使用
2避免层级叠加
3自定义View使用clipRect屏蔽被遮盖View绘制
data:image/s3,"s3://crabby-images/4fbbc/4fbbcee2c1be71caacfa7f68ce20a044e141329f" alt=""
data:image/s3,"s3://crabby-images/7ebf3/7ebf31aa2121da3164ab7811242232f93235256b" alt=""
去掉background后
data:image/s3,"s3://crabby-images/9655d/9655d2effff12bf887186d49edebacf686bcf78c" alt=""
自定义view要如下修改
data:image/s3,"s3://crabby-images/557af/557afd98ff3b689b2549a294bd704e294fc0d98f" alt=""
data:image/s3,"s3://crabby-images/adfe5/adfe54bf4ffdfa632e5ddb6d2a0f43e6ee1f2d7b" alt=""
其他
Viewstub:高效占位符、延迟初始化
onDraw中避免:创建大对象、耗时操作
TextView优化:(有专项讲解)
7模拟面试
布局优化中用到哪些工具?
不同场景不同工具
统计线上FPS --》Choreographer 实时的
获取加载耗时 AOP/Hook
线下使用 systrace 、Layout Inspector
布局为什么导致卡顿,你怎么优化的
IO、反射、遍历、重绘
异步Inflate、X2C,减少 层级、重绘
AOP、监控
做完布局优化有哪些成果
体系化的监控手段:线下+线上
指标:FPS、加载时间、布局层级
上线前对核心路径保障review
网友评论