1 减少过渡绘制
data:image/s3,"s3://crabby-images/9754e/9754e1073750308d1373b30415fdcbf88235d75b" alt=""
不存在过度绘制,Item的布局的也不存在过度绘制
1. 自定义 View 时重写 hasOverlappingRendering 方法返回false。
无自定义View
2 布局优化
2.1 减少布局的嵌套层级
原则:
1,用RelativeLayout减少嵌套的层级。
2,同等层级情况下可以实现的选用LinearLayout而不是RelativeLayout。
data:image/s3,"s3://crabby-images/1aa21/1aa2131bb78d804887287e624242c187a10d79fd" alt=""
就一层嵌套,这样的布局也不能用LinearLyaout来布局,所以嵌套层级无需优化。
2.2 当某些UI满足某种条件才显示复杂UI就用ViewStub
无满足某种条件才显示的复杂UI。这条无需优化。
2.3 有些大像素有规律的图片用.9去代替
无大像素有规律的图片,这条无需优化。
2.4 去掉无用的UI
无无用的UI。这里无需优化。
2.5 合并布局,用TextView代替图片加文字
虽然图片加文字可以合并的,但是那个图片是自定义View,合并改变代码过多。改了也不会带来特别大的性能好处。可以忽略。
3 分析代码耗时情况
3.1
data:image/s3,"s3://crabby-images/43c30/43c3016d7379c3fef2effd07851269d6e52a9b3e" alt=""
找到一个耗时函数,看他的方法内容,inflate方法占了大部分,这个是就是加载Item的布局。但是我们的布局已经改成一层嵌套了。所以这布局无法再改了。
3.2
data:image/s3,"s3://crabby-images/5dbd3/5dbd38e0d2d7978e13655da8b12e0d53b2ad65a5" alt=""
这方法里面的bindCallLogListViewHolder()方法耗时。
点bindCallLogListViewHolder方法(76序号)
data:image/s3,"s3://crabby-images/7ac7e/7ac7ea45da5c0024c3093f7c769e1c5436e6c5d1" alt=""
看得出来,前面的这三个方法耗时。那么我们一一分析这个三个方法。
先看setPhoneCallDetails,点104序号的setPhoneCallDetails方法。
data:image/s3,"s3://crabby-images/b0ffb/b0ffb8c862c3398036412a41f05f4c6a69ae5e50" alt=""
同上序号147的setPhoneCallDetails和序号161getCallDescription耗时。
一直往下跟,跟到join这个方法。
data:image/s3,"s3://crabby-images/e2817/e2817ce3862b6bd033d28654b64f76eec25192cc" alt=""
BidiFormatter.unicodeWrap耗时。
代码是这样的:
data:image/s3,"s3://crabby-images/aafe4/aafe49d8d424b5f02aded41ce24b249f7be90402" alt=""
得知道这个代码的作用是干啥的?
data:image/s3,"s3://crabby-images/a8b1c/a8b1c0aefb7a3e13070ba7640a62334d6bd83d2f" alt=""
那不是说不能改了吗?
当然不是了。
TextView有一个属性可以专门解决这种问题:
setTextDirection(View.TEXT_DIRECTION_LTR)
所以上述代码就可以改成:
data:image/s3,"s3://crabby-images/610da/610da64ce9f6b910c844b05be0e52ed6c56f04b5" alt=""
data:image/s3,"s3://crabby-images/5bc7f/5bc7fc5f93afa722bbab636b51655357753562e8" alt=""
给Textiview设置setTextDirection(View.TEXT_DIRECTION_LTR)这个属性。
改好运行修改后的代码。生成.TraceView对比修改的结果。
搜索join看优化成果,
data:image/s3,"s3://crabby-images/4f84c/4f84ce5da1ce6d3fc3977ba48f9a937aeff3cb2e" alt=""
data:image/s3,"s3://crabby-images/c46cb/c46cb4f48ff177f2158fac88c79445f14747da1e" alt=""
是不是没有了BidiFormatter.unicodeWrap的耗时了吗?这不是废话吗?注销掉了肯定会没有了呢?至于数据为什么好像比优化前要跟耗时。这是traceView检查问题,和代码的每次的执行时间有不一样的。误差范围内。
网友评论