如何将数据库中的数据显示到具有高性能的RecyclerView?

yww*_*ynm 5 sqlite android android-adapter android-cursoradapter android-recyclerview

我为RecyclerView编写了自己的CursorAdapter,如下面的链接:https://gist.github.com/skyfishjy/443b7448f59be978bc59

然后我发现每当我在数据库中更改某些东西并希望在RecyclerView中显示它时,我需要通过db.query()创建一个新的Cursor并使用CursorAdpater的changeCursor().由于query()将扫描数据库中的所有行,因此即使我只将一行插入数据库,当数据量很大时,RecyclerView也会缓慢刷新.

此外,众所周知,RecyclerView为开发人员提供了notifyItemInserted/Removed(position),以便RecyclerView可以部分刷新,这对内存/时间有用且有益.但是,当我使用CursorAdapter时,我不知道何时以及如何使用这些方法,因为更改光标不会直接向使用RecyclerView的数据集绑定添加内容,而是实际刷新所有项目.

那么有没有更好的方法在RecyclerView中显示数据库中的数据并使用RecyclerView的改进方法来显示各种数据库?

EE6*_*E66 4

我可以告诉你我做了什么... A. 使用 Loader 加载游标。B. 将光标复制到附加到适配器的 arraylist 中(光标不是直接附加到适配器),关闭光标。如果没有很多数据,效果很好 - 如果有很多行,那么我会将其中一些加载到数组列表中,然后当用户向下滚动时,我会再次查询并从数组的最后一行加载。C. 当用户想要删除或添加某些内容时,我会首先在 arrayList 上执行操作(UI 线程)notifiyItemChanged,然后更改数据库(返回线程)希望我有所帮助。