博客
关于我
ListView最终优化方法,绝对流畅
阅读量:715 次
发布时间:2019-03-21

本文共 1466 字,大约阅读时间需要 4 分钟。

ListView在Android开发中是一个常用的UI控件,但在实际应用中,由于数据量大、布局复杂、资源占用高等原因,容易导致列表滚动卡顿甚至 crash。针对这些问题,我进行了细致的优化,现将优化方法总结如下:

1. Adapter 的优化

首先,我意识到Adapter是ListView性能优化的关键。为了提升性能,我在Adapter中使用 static ViewHolder。这可以避免每次 retrieve ViewHolder 时所带来的类方法 invocation的开销,从而减少了列表渲染的时间。

ViewHolder 的优化

  • 静态 ViewHolder: 通过使用 static 关键字,确保 ViewHolder 在 Adapter 中被静态地初始化和缓存起来。这避免了每次创建.ViewHolder() 调用带来的开销。
  • 减少 findView �498 操作: ViewHolder 会存储当前显示 item 中的 View 组件,避免每次在 Adapter 的 Gibson 方法中不停地调用 convertView.findViewById(...),这可以提高渲染效率。

2. 数据的分批加载

为了避免一次性加载过多数据带来的性能瓶颈,我在 Adapter 中使用 CursorLoaderAsynclistView 进行分批数据加载。

CursorLoader 和 AsynclistView

  • 分批处理: CursorLoader 负责从数据库或网络获取分批数据,并在优雅的方式上填充 Adapter。这种方式避免了在主线程上处理大批量数据。
  • AsynclistView: 这个库可以提供更好的滚动时数据加载的控制权,可以避免 Adapter 的 getView 方法中出现长时间的阻塞。

3. 图片和文字分离操作优化

在之前的实现中,每个 item 的图片和文字场景都需要进行耗时的操作,如图片加载和 getTextWith Span-info 的设置,这些操作都对性能有很大负担。

图片加载优化

  • 使用 Glide: Glide 是一个高效的图片缓存和加载框架,可以根据需要缓存图片,并快速加载。这避免了频繁的图片加载带来的性能损失。
  • 预先加载图片: 在 Adapter 初始化的时候,会预先为每个 item 加载图片并将其存储起来。当 item 显示的时候,只需要简单地绘制就可以了。

字体加载优化

  • 提前加载字体: 将字体加载的操作放在 Activity 的 onCreate 方法中完成,并将字体文件存储起来。这确保了字体在 item 获取的时刻已经完成,避免了在每个 item 中进行耗时的操作。
  • 使用 RoboFontLIGHT: 选择更轻量izzz的字体文件,减少字体加载的时间和内存占用。

4. 开启分隔线优化

为了让 listviewmore美观和流畅,还对 item 的之间的间距进行了优化。

分隔线的计算

基于 screen height 和用户体验需求,计算每个 item 的间距。这通过动态设置 item 的高度来实现,让 listview的展示更加舒适。

5. 总结优化效果

通过以上方法,我的ListView 已经变得非常流畅。

  • 用户体验提升: 滚动时几乎无卡顿,页面刷新更快速。

  • 性能优化: 减少了主线程的操作,提升了 UI 线程的响应速度。

  • 系 统优化: 代码结构更清晰,易于维护和扩展。

这些优化方法不仅提升了列表的性能表现,还为后续的功能开发奠定了稳健的基础。

转载地址:http://ryfrz.baihongyu.com/

你可能感兴趣的文章
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_说明操作步骤---大数据之Nifi工作笔记0028
查看>>