RecyclerView 一次性加载大量数据时(2000条音频数据),导致UI线程卡顿,频繁GC的问题

news/2024/7/5 3:57:38

问题描述:

        公司项目有这么一个需求,扫描sdCard或U盘的音频数据,并分类展示出来,当数据量比较大时(2000多条数据以上),显示列表慢和滑动列表会很卡。

问题的寻找过程:

当时想的就是因为数据过多导致页面绘制的时候卡主线程了。

因为我是通过RecyclerView展示数据的,接着就想到一次性加载2000多条数据会卡顿,那我就分批加载,我将2000多条数据按每100条一批,显示到RecyclerView中,然后发现问题依然存在。被这个问题困住了,试了各种分页加载,依然得不到解决。

后来排查在adapter的onCreateViewHolder() 和 onBindViewHolder()中打了个计数的Log,发现2000多条数据,每条数据加载的时候都会调用onCreateViewHolder()和onBindViewHolder()。这就有问题了,根据官方API的说明,RecyclerView只会 create当前显示的Item,其他的未显示的都是通过ViewHolder的复用来显示的,我想我已经发现问题所在了。

然后我就想是不是我adapter写的有问题呢 ,经过和其他页面RecyclerView 的adapter的对比,却发现并没有什么不同,这让我又开始苦恼起来。

经过和其他页面的一步步的对比,最终发现原来是activity中的布局文件中,RecyclerView 的父布局使用了android:layout_weight百分比例属性设置宽度,导致RecyclerView 的每一条数据都会创建一个Item,在数据量小的时候发现不了,等数据量达到一定程度的时候就会导致由于创建的View过多,程序运行过程中产生了大量的垃圾数据,所以才会导致进程不断的发生GC,因而影响了UI主线程。

出现问题的布局文件:

<LinearLayout

       android:layout_width="0dp"

        android:layout_height="match_parent"

        android:layout_weight="1">

                   <RecyclerView

                        android:layout_width="match_parent"            

                        android:layout_height="match_parent"        />

  </LinearLayout>

解决办法:

1、子布局和父布局的宽度和高度不使用layout_weight设置百分比相对宽高,因此去掉此属性后,问题就解决了。

2、经过百度发现

//设置 这个可以避免以上问题 但也意味着失去了本身设计用来提供支持WRAP_CONTENT的功能了mRecyclerView.getLayoutManager().setAutoMeasureEnabled(false);

貌似也能解决,不过我还没有试过。


 


http://lihuaxi.xjx100.cn/news/1375193.html

相关文章

spring6——概述

文章目录 概述Spring 是什么&#xff1f;Spring 的狭义与广义Spring Framework特点Spring模块组成 概述 Spring 是什么&#xff1f; Spring 是一款主流的 Java EE 轻量级开源框架 &#xff0c;Spring 由“Spring 之父”Rod Johnson 提出并创立&#xff0c;其目的是用于简化 J…

利用FME实现批量提取图斑特征点、关键界址点提取、图斑拐点抽稀,解决出界址点成果表时点数过多问题的方法

目录 一、实现效果 二、实现过程 1.提取图斑界址点 2.计算各界址点的角度 3.筛选提取关键界址点 三、总结 对于范围较大的图斑&#xff0c;界址点数目较大&#xff0c;在出界址点成果表前&#xff0c;往往需要对界址点进行处理&#xff0c;提取出关键特征点作为出界址点成…

SIGIR 2023 | 语音让对话推荐更easy,火山语音联合新加坡科学研究院发布业内首个语音对话推荐数据集

近年来&#xff0c;推荐系统在工业界取得了巨大成功&#xff0c;甚至成为互联网发展中不可或缺的增长引擎&#xff0c;基于此研究者们也在积极探索推荐系统的新形态&#xff0c;其中对话推荐系统&#xff08;Conversational Recommender System&#xff0c;简称CRS&#xff09;…

利用 trait 实现多态

我在书上看到基于 std::io::Write 的示例&#xff0c;它是一个 trait 类型&#xff0c;内部声明了一些方法。和 go 语言不同&#xff0c;rust 中类型必须明确实现 trait 类型&#xff0c;而 go 语言属于 duck 模式。 std::io::Write下面的例子中调用 write_all 方式来演示&…

01 矩阵(力扣)多源广度优先搜索 JAVA

给定一个由 0 和 1 组成的矩阵 mat &#xff0c;请输出一个大小相同的矩阵&#xff0c;其中每一个格子是 mat 中对应位置元素到最近的 0 的距离。 两个相邻元素间的距离为 1 。 输入&#xff1a;mat [[0,0,0],[0,1,0],[0,0,0]] 输出&#xff1a;[[0,0,0],[0,1,0],[0,0,0]] 输入…

2023百强县名单出炉!千亿县达54个

作为国民经济发展中的基本单元&#xff0c;县域经济发挥着重要作用。 赛迪顾问25日发布的《2023中国县域经济百强研究》&#xff08;下称“报告”&#xff09;显示&#xff0c;千亿县达54个&#xff0c;百强县前10名中江苏省独占6席。 在百强县前10名中&#xff0c;江苏省占席最…

如何在3ds max中创建可用于真人场景的巨型机器人:第 1部分

推荐&#xff1a; NSDT场景编辑器助你快速搭建可二次开发的3D应用场景 1. 创建主体 步骤 1 打开 3ds Max。 打开 3ds Max 步骤 2 在左侧视口中&#xff0c;按键盘上的 Alt-B 键。它 打开视口配置窗口。 打开“锁定缩放/平移”和“匹配位图”选项。单击“文件”并转到参考 …

Python数据分析实战-利用limit 与 offset进行数据库数据批量查询与处理(附源码和实现效果)

实现功能 利用limit 与 offset进行数据库数据批量查询与处理 实现代码 def query_batch(self,engine,batch_step,end,sql):session make_session(engine)cursor session.execute(sql.format(batch_step, end))fields cursor._metadata.keysdf pd.DataFrame([dict(zip(fi…