Android:在后台使用SQLiteCursor / SimpleCursorAdapter

我的问题与Android有关.我有以下代码(省略了不相关的部分):

public class MyActivity extends ListActivity {
    protected void onResume() {
        super.onResume();
        new UpdateTask().execute();
    }

    private class UpdateTask extends AsyncTask<Object, Object, listadapter> {
        protected listadapter doInBackground(Object... params) {
            sqliteCursor cursor = db.getSomeData();
            startManagingCursor(cursor);
            SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, ..., cursor, ..., ...);
            return adapter;
        }

        protected void onPostExecute(listadapter result) {
            listView.setAdapter(result);
        }
    }
 }

这会导致RuntimeException-在实例化SimpleCursorAdapter的行上,“无法在未调用Looper.prepare()的线程内创建处理程序”.

我了解为什么会这样,只是不知道如何解决(将其保存在单独的线程中).我发现了这个线程:

http://groups.google.com/group/android-developers/browse_thread/thread/34d0069bb2de925e?fwc=2

但是我真的不明白答复.我没有用谷歌搜索任何
涉及sqliteCursor和AsyncQueryHandler的示例.

你们能帮忙吗?谢谢.

解决方法:

看起来实例化SimpleCursorAdapter必须在UI线程上进行.您可以通过让doInBackground()返回光标并在onPostExecute()中设置适配器来实现.

如果还没有,请参见Painless Threading.

相关文章

Android性能优化——之控件的优化 前面讲了图像的优化,接下...
前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要...
最近项目重构,涉及到了数据库和文件下载,发现GreenDao这个...
WebView加载页面的两种方式 一、加载网络页面 加载网络页面,...
给APP全局设置字体主要分为两个方面来介绍 一、给原生界面设...
前言 最近UI大牛出了一版新的效果图,按照IOS的效果做的,页...