相关疑难解决方法(0)

ContentProvider insert()总是在UI线程上运行?

我有一个应用程序需要从服务器提取数据并将其插入SQLite数据库以响应用户输入.我认为这很简单 - 从服务器提取数据的代码是AsyncTask的一个相当简单的子类,它完全按照我的预期工作,而不会挂起UI线程.我使用一个简单的接口为它实现了回调功能,并将其包装在一个静态类中,所以我的代码如下所示:

MyServerCaller.getFolderContents(folderId, new OnFolderContentsResponseListener() {
    @Override
    public void onFolderContentsResponse(final List<FilesystemEntry> contents) {
        // do something with contents
    }
}
Run Code Online (Sandbox Code Playgroud)

一切都还不错.即使服务器需要一个小时来检索数据,UI仍然可以顺利运行,因为getFolderContents中的代码在AsyncTask的doInBackground方法中运行(该方法与UI分开).在getFolderContents方法的最后,调用onFolderContentsResponse并传递从服务器接收的FilesystemEntry列表.我只是真的说了这一切,所以我希望很清楚我的问题不在getFolderContents方法或我的任何网络代码中,因为它不会在那里发生.

当我尝试通过onFolderContentsResponse方法中的ContentProvider子类插入数据库时​​出现问题; 在执行该代码时,UI总是挂起,这使我相信尽管从AsyncTask的doInBackground方法调用,插入仍然在UI线程上运行.以下是有问题的代码:

MyServerCaller.getFolderContents(folderId, new OnFolderContentsResponseListener() {
    @Override
    public void onFolderContentsResponse(final List<FilesystemEntry> contents) {
        insertContentsIntoDB(contents);
    }
}
Run Code Online (Sandbox Code Playgroud)

insertContentsIntoDB方法:

void insertContentsIntoDB(final List<FilesystemEntry> contents) {
    for (FilesystemEntry entry : contents) {
        ContentValues values = new ContentValues();
        values.put(COLUMN_1, entry.attr1);
        values.put(COLUMN_2, entry.attr2);
        // etc.

        mContentResolver.insert(MyContentProvider.CONTENT_URI, values);
    }
}
Run Code Online (Sandbox Code Playgroud)

其中mContentResolver先前已设置为getContentResolver()方法的结果.

我已经尝试将insertContentsIntoDB放在自己的Thread中,如下所示:

MyServerCaller.getFolderContents(folderId, new OnFolderContentsResponseListener() {
    @Override
    public void onFolderContentsResponse(final List<FilesystemEntry> contents) { …
Run Code Online (Sandbox Code Playgroud)

java user-interface multithreading android android-contentresolver

35
推荐指数
1
解决办法
9004
查看次数

Android SQLite查询,插入,更新,删除,总是需要在后台线程?

我目前使用Loaders从我的ContentProvider中获取数据(以启用我的游标的自动更新).这种方法对于查询数据库是直截了当的,但它似乎不适合任何其他数据库操作(例如插入,更新,删除).

我的问题是:

  1. 是否所有SQLite操作都需要在后台线程上,或者在UI线程上执行插入,更新或删除单行等简单操作是否安全?
  2. 什么是一个很好的设计模式,以确保所有查询都通过后台线程?我想实现AsyncTask,我应该创建一个SuperTask,这样可以扩展AsyncTask并执行每个SQLite操作吗?(额外奖励:你能提供简单的例子吗?)

sql multithreading android loader android-asynctask

14
推荐指数
2
解决办法
1万
查看次数