【问题标题】:Subclass of SQLiteDatabaseHelper throws NullpointerException when calls getReadebleDatabase()SQLiteDatabaseHelper 的子类在调用 getReadebleDatabase() 时抛出 NullpointerException
【发布时间】:2015-06-18 05:39:28
【问题描述】:

我有一个名为DatabaseSuperSQLiteDatabaseOpenHelper 子类,它覆盖onCreateonUpdate 方法。 DatabaseController 类是 DatabaseSuper 的子类,旨在实现所有应用程序特定的数据库操作。

我的问题是,当我在DatabaseController 类的方法中调用getReadableDatabase() 时,它会触发Nullpointer exception。 但是,如果我将SQLiteDatabase 对象作为参数传递给从基类(DatabaseSuper) 获取的该方法,则不会抛出异常。

方法

public String sendDate(SQLiteDatabase db) {

    //SQLiteDatabase db = getReadableDatabase();                 *line 1*

    Cursor cursor = db.rawQuery("select date from todo", null);
    StringBuffer stringBuffer = new StringBuffer();
    while (cursor.moveToNext()) {
        String date = cursor.getString(0);  
        stringBuffer.append(date + ":");
    }
    cursor.close();
    return stringBuffer.toString();
}

从活动类调用方法

String data = dataControllerObject.sendDate(new DatabaseSuper(this).getReadableDatabase());

错误

06-18 04:28:50.239: E/AndroidRuntime(5147): 
FATAL EXCEPTION: main
06-18 04:28:50.239: 
E/AndroidRuntime(5147): 
java.lang.RuntimeException:Unable to start activity ComponentInfo{com.example.dolist/com.example.dolist.SearchListView}:
java.lang.NullPointerException
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
06-18 04:28:50.239:

E/AndroidRuntime(5147):     
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.app.ActivityThread.access$600(ActivityThread.java:141)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.os.Handler.dispatchMessage(Handler.java:99)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.os.Looper.loop(Looper.java:137)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.app.ActivityThread.main(ActivityThread.java:5041)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at java.lang.reflect.Method.invokeNative(Native Method)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at java.lang.reflect.Method.invoke(Method.java:511)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at dalvik.system.NativeStart.main(Native Method)
06-18 04:28:50.239: E/AndroidRuntime(5147):
Caused by: java.lang.NullPointerException
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:224)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.database.sqlite.SQLiteOpenHelper.getReadableDatabase(SQLiteOpenHelper.java:188)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at com.example.dolist.DataController.sendDate(DataController.java:37)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at com.example.dolist.SearchListView.onCreate(SearchListView.java:34)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.app.Activity.performCreate(Activity.java:5104)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
06-18 04:28:50.239: E/AndroidRuntime(5147):
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
06-18 04:28:50.239: E/AndroidRuntime(5147):
... 11 more

【问题讨论】:

  • 使用this.getReadableDatabase(); 而不是getReadableDatabase();

标签: android sqlite android-sqlite android-database


【解决方案1】:

在构造函数中传递给SQLiteOpenHelperContextnull

在调用部分

String data = dataControllerObject.sendDate(new DatabaseSuper().getReadableDatabase());

您实际上并没有在没有任何参数的情况下传入任何 Context - new DatabaseSuper()SQLiteOpenHelper 超类构造函数需要一个,因此您可能传入了一个显式的null。如需详细帮助,请发布您的构造函数代码。

【讨论】:

  • 对不起,我已经将上下文参数传递给了构造函数,但是这里忘记了。
  • 即使这样,异常也是关于将错误的Context 传递给SQLiteOpenHelper
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2020-05-11
  • 2018-08-13
  • 1970-01-01
  • 2012-08-02
  • 1970-01-01
  • 2017-12-25
  • 1970-01-01
相关资源
最近更新 更多