3

我想在手机启动时搜索数据库并敬酒特定列。即使我觉得代码是正确的,该应用程序也会不断崩溃并出现异常。

@Override
public void onReceive(Context ctx, Intent intent) {
    Log.d("omg", "1");
    DBAdapter do = new DBAdapter(ctx);
    Log.d("omg", "2");
    Cursor cursor = do.fetchAllItems();
    Log.d("omg", "3");
    if (cursor.moveToFirst()) {
        Log.d("omg", "4");
        do {
            Log.d("omg", "5");
            String title = cursor.getString(cursor.getColumnIndex("item"));
            Log.d("omg", "6");
            // i = cursor.getInt(cursor.getColumnIndex("id"));
            Toast.makeText(ctx, title, Toast.LENGTH_LONG).show();

        } while (cursor.moveToNext());
    }
    cursor.close();
}

令人沮丧的是,我没有看到我的任何“omg”日志出现在 logcat 中。我只看到我的应用程序崩溃。

我在 logcat 中收到三行错误。

10-19 12:31:11.656: E/AndroidRuntime(1471): java.lang.RuntimeException: Unable to start receiver com.test.toaster.MyReciever: java.lang.NullPointerException
10-19 12:31:11.656: E/AndroidRuntime(1471):     at com.test.toaster.DBAdapter.fetchAllItems(DBAdapter.java:96)
10-19 12:31:11.656: E/AndroidRuntime(1471):     at com.test.toaster.MyReciever.onReceive(MyReciever.java:26)

对于任何感兴趣的人,这是我的 DBAdapter fetchAllItems 代码:

public Cursor fetchAllItems() {
    return mDb.query(DATABASE_TABLE, new String[] { KEY_ITEM, KEY_PRIORITY,
            KEY_ROWID }, null, null, null, null, null);
}
4

1 回答 1

2

问题在于mDbnullfetchAllItems()需要mDb在尝试使用它之前进行初始化。

这只是一个猜测,但许多 DBAdapter 设计都有一个open()方法,是你的吗?如果是这样,您只需在调用之前调用它fetchAllItems()。如果没有,您仍然需要调用mDb = ...适配器中的某个位置。

于 2012-10-19T16:58:33.637 回答