加载来自游标的数据崩溃onLoadFinished

时间:2014-02-06 02:38:13

标签: java android loader simplecursoradapter android-cursorloader

在我的应用程序中,我正在使用Loader检索联系人数据。我调试了应用程序,发现应用程序在onLoadFinished回调中发生的第一个语句崩溃。

以下是代码:

@Override
public void onLoadFinished(Loader<Cursor> arg0, Cursor arg1) {
    Log.d("Loader","Load Finished");
    mAdapter.changeCursor(arg1);

    phonenumber_enter.setAdapter(mAdapter);

}

我发现应用程序在回调的第一行崩溃(在这种情况下,应用程序在记录消息时崩溃)。这是logcat:

02-05 21:31:07.357: E/AndroidRuntime(31707): java.lang.RuntimeException: An error occured while executing doInBackground()
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.support.v4.content.ModernAsyncTask$3.done(ModernAsyncTask.java:137)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at java.util.concurrent.FutureTask.run(FutureTask.java:242)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at java.lang.Thread.run(Thread.java:841)
02-05 21:31:07.357: E/AndroidRuntime(31707): Caused by: java.lang.IllegalArgumentException: Invalid column data1
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:167)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:137)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.content.ContentProviderProxy.query(ContentProviderNative.java:413)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.content.ContentResolver.query(ContentResolver.java:461)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.content.ContentResolver.query(ContentResolver.java:404)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.support.v4.content.CursorLoader.loadInBackground(CursorLoader.java:49)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.support.v4.content.CursorLoader.loadInBackground(CursorLoader.java:35)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.support.v4.content.AsyncTaskLoader.onLoadInBackground(AsyncTaskLoader.java:242)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.support.v4.content.AsyncTaskLoader$LoadTask.doInBackground(AsyncTaskLoader.java:51)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.support.v4.content.AsyncTaskLoader$LoadTask.doInBackground(AsyncTaskLoader.java:40)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at android.support.v4.content.ModernAsyncTask$2.call(ModernAsyncTask.java:123)
02-05 21:31:07.357: E/AndroidRuntime(31707):    at java.util.concurrent.FutureTask.run(FutureTask.java:237)

我看到没有data1列但是这应该没有区别,因为Cursor加载器的创建方式如下:

@Override
public Loader<Cursor> onCreateLoader(int arg0, Bundle arg1) {
    return new CursorLoader(getActivity(),
            ContactsContract.Contacts.CONTENT_URI, null, null, null,
            null);
}

由于投影为null,我认为将选择所有可能的列。调试后,我发现游标中没有名为data1的列。任何想法都会非常感激。

编辑: 我刚刚测试了应用程序,当我将调试器附加到应用程序时,似乎没有发生崩溃。虽然没有返回游标,但似乎加载器没有正常工作。

编辑2: 好的,我再次调试了应用程序并查看了光标返回的所有列。没有列包含电话号码。这是最初的陈述:

CursorLoader(getActivity(),
            ContactsContract.Contacts.CONTENT_URI, null, null, null, null);

有什么想法吗?

1 个答案:

答案 0 :(得分:0)

好的,所以在搞乱后我发现原始语句不正确(我查询错误的数据库)。我改变了:

CursorLoader(getActivity(),
        ContactsContract.Contacts.CONTENT_URI, null, null, null, null);

CursorLoader(getActivity(),
            ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, null,
            null, null);