- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我知道这已经讨论过了,但我想问一下目前的情况。我是否必须创建一个 ContentProvider 才能将 CursorLoader 与 sqlite 数据库结合使用?
我找到了
CursorLoader usage without ContentProvider
正如 Emmby 评论的那样,看起来正是我所希望的
所以提到了另一种解决方案
https://github.com/commonsguy/cwac-loaderex
再次指出一些缺点
当然,在使用 LoaderManager 时,我们希望获得引入它的所有好处。所以我的问题是,是否有一种方法可以将 LoaderManager 与 sqlite 数据库结合使用,而无需实现内容提供程序,但仍能获得它的所有好处。
谢谢
最佳答案
您在帖子中提到的两个实现都提供了 CursorLoader
除了 能够在基础内容更改时接收通知的所有好处。
我最近一直在研究这个问题,我可以自信地告诉你,Android API 目前不提供仅使用原始 SQLiteDatabase
的方法(它只提供 ContentResolver#notifyChange()
和 Cursor#setNotificationUri()
方法,用于通知在某个通知 Uri 下注册的所有
)。Cursor
也就是说,您现在的选择是:
自己实现一个观察者,它能够在内容更改时从 SQLiteDatabase
接收通知,并且能够以某种方式将这些通知中继到所有现有的 Loader
s 在您的应用程序中。我写了一个相当广泛的blog post关于如何实现Loader
s,如果你想接受这个挑战,可能会派上用场。或者……
使用 Mark Murphy 的 LoaderEx
库,并且只使用他的库提供的 AsyncTask
操作来修改数据库。请注意,他的任务之所以刷新 Loader
是因为它们在执行插入/更新/删除后立即在 Loader
上调用 onContentChanged
,有效地告诉 Loader
内容已更改并且应该刷新其数据。
只需使用 ContentProvider
和 CursorLoader
即可使用 ContentResolver#notifyChange()
方法通知 CursorLoader
内容发生了变化。
我正在尝试找出一个更好的解决方案,如果我找到/实现一个解决方案,我会在未来报告,但现在必须这样做。
关于android - 没有 Content Provider 的 CursorLoader 和 SQLite,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12869373/
我有两个具有 1:n 关系的表,我正在使用内容提供程序和 cursorloader。 如何进行连接查询以使用游标加载器?我可以在内容提供程序中使用 rawSql 以某种方式破解它,但如何在游标加载器构
我有一个 CursorLoader 从本地 SQLite 数据库加载数据。 SQLite 中的数据实际上是远程 API 响应的缓存副本,所以我会在 SQLite 数据出现时启动异步刷新由 Cursor
正在寻找在 CursorLoader 上查询(或执行搜索功能)的简单方法...我尝试了 SearchView 并且可以加载数据,但是一旦我尝试搜索,应用程序就会崩溃。 .有什么想法吗? package
我尝试使用 CursorLoader,但我不明白如何填写参数。 对于我的应用程序,我需要在一列中观察该值是否为 false 并获取该行的 id。 String[] projection =
我正在创建应用程序以通过外部 Web 服务将电影数据添加到内部数据库并显示电影列表作为 ListFragment 中的主要 Activity ,另一个 Activity 负责搜索功能。上面提到的 Li
我在调试空指针异常时遇到了一些困难。 E/AndroidRuntime( 1760): java.lang.RuntimeException: Unable to instantiate applic
我正在尝试从联系人中查询昵称和 SIP 地址。我遇到的问题是它们都存储在 DATA1 列中。所以当我运行查询时,我只检索昵称。检索它们并将它们传递到下面的 SimpleCursorAdapter 的方
我已经实现了我的自定义 ContentProvider,它有几个 URI: 主要的: //Return all items, uriType = ALLITEMS String BASEURI = "
在以下情况下如何合并游标加载器以获得一个游标加载器。我不止一个地调用内容提供者来创建我的数据库适配器以与简单的游标适配器一起使用。请看下面我的代码。 @Override public Loader o
我构建了一个可以显示我所有联系人的 Android 应用程序。这是我的 Cursor 的样子: public Cursor getAllContacts() { CursorLoader cl
好吧,我很困惑。两者有什么区别?我一直在使用导入到 Assets 文件夹中的预制数据库,并在我的 ListView 中使用图像,并且在向下滚动时遇到内存不足的错误。我阅读了不同的处理方法,但可以真正理
我刚开始使用新的 cursorLoader,但遇到了问题。以下代码只是为了了解 cursorLoader 的工作原理,但我不断得到: 当我恢复此 Activity 时,“正在尝试重新查询已关闭的游标”
我需要实现分页列表,它使用 Loader 从 ContentProvider 获取 Cursor。我有页脚,当用户单击它时 - 我需要将下一条记录添加到列表中。 如何使用 Loader 刷新列表中的数
我有两个 1:1 关系的表,我正在使用内容提供程序和游标加载器。 我将如何进行连接查询以使用游标加载器?我可以在内容提供程序中使用 rawSql 以某种方式破解它,但我无法在游标加载器构造函数中进行操
在我的应用程序中,我想显示我放在资源文件中的应用程序列表。我解析 XML(资源)文件,然后将值保存在 SQLiteDatabase 中。我在 ContentProvider 中实现了我的数据库。我想知
我在 ListFragment(位于 ViewPager 内)中有一个 CursorLoader 用于查询数据库。我有一个该数据库的内容提供者,我已经验证了它的工作原理。 问题是这样的:当应用程序首次
我在我的应用程序中广泛使用 Cursors 来加载和偶尔从数据库写入信息。我已经看到 Honeycomb 和 Compatibility Package 具有新的 Loader 类,旨在帮助以“好的”
我正在开发一个客户端 android 应用程序,该应用程序将从 URL 检索数据并将其保存在本地数据库中。我熟悉使用 SQLiteDatabase对于这个操作。 当我阅读 SimpleCursorAd
首先,我尝试使用 fts3 sqlite 表在 Android 上进行搜索,但它不起作用,因为它默认不支持括号。 我注意到,CursorLoader()在执行时会自动将选择参数(where子句)放在括
使用CursorLoader时应该在哪里处理查询结果(耗时的任务)? 最佳答案 使用AsyncTask从游标加载数据并在onPostExcute方法(uiThread)中返回值,当你多次调用任务时取消
我是一名优秀的程序员,十分优秀!