android UI卡顿问题学习

  转自https://blog.csdn.net/joye123/article/details/79425398

https://blog.csdn.net/zhenjie_chang/article/details/52584967

 

  卡顿优化

  卡顿:从用户角度说,App操作起来缓慢,响应不及时,列表滑动一顿一顿的,动画刷新不流畅等等一些直观感受。从系统角度来说,屏幕刷新的帧率不稳定,无法保证每秒绘制60帧,也就是说有掉帧的情况发生。

 

  对于开发过程,出现卡顿的主要原因是主线程做了一些不该做的事,或者主线程做不了事情了。

  • 布局渲染(解析、测量、布局、渲染)
  • 动画执行
  • Binder通信
  • 界面响应

  主线程主要是做以上四个方面的工作,如果在主线程做一些耗时操作(网络请求、IO读写等),或者被其他线程挂起(GC),那么页面刷新无法在16ms内完成,就会出现掉帧的情况。

 

 

    

  • 原色:没有过度绘制
  • 蓝色:过度绘制1次
  • 绿色:过度绘制2次
  • 粉色:过度绘制3次
  • 红色:过度绘制4次或更多

  请注意,这些颜色是半透明的,因此,您在屏幕上看到的确切颜色取决于您的界面内容。可以通过此功能查看哪些页面的布局层级过深。

 

  

  常见卡顿原因及解决方案

 

  过度绘制

    去除不必要的背景色

  • 设置窗口背景色为通用背景色,去除根布局背景色。
  • 若页面背景色与通用背景色不一致,在页面渲染完成后移除窗口背景色
  • 去除和列表背景色相同的Item背景色

    布局视图树扁平化

  • 移除嵌套布局
  • 使用merge、include标签
  • 使用性能消耗更小布局(TableLayout、ConstraintLayout)

    减少透明色,即alpha属性的使用

  • 通过使用半透明颜色值(#77000000)代替

    其他

  • 使用ViewStub标签,延迟加载不必要的视图
  • 使用AsyncLayoutInflater异步解析视图

 

  主线程耗时操作

  • Json数据解析耗时(Cache类)
  • 文件操作(获取所属渠道名称)
  • Binder通信(获取系统属性(mac地址))
  • 正则匹配(Hybird 通信)
  • 相机操作:初始化、预览、停止预览、释放(反扫)
  • 组件初始化(推送)
  • 循环删除、创建View(更多页面)
  • WebView首次初始化

 

布局优化的一些策略

1. <include>标签
2. <viewstub>标签
3.<merge>标签
4.去除不必要的嵌套和View节点
5.减少不必要的infalte
6.View局部更新

posted @ 2019-01-10 14:38  clutch1992  阅读(683)  评论(0编辑  收藏  举报