【问题标题】:SQLiteOpenHelper: NullPointerExceptionSQLiteOpenHelper: NullPointerException
【发布时间】:2014-03-23 22:57:13
【问题描述】:

我正在尝试将数据保存到 SQLite 数据库。

AddBook.java

    public class AddBook extends Activity {
        String myUrl = "";
        DownloadBook obj_Downloadbook;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            obj_Downloadbook = new DownloadBook(AddBook.this);//line26
    ...
    obj_Downloadbook.execute(myUrl);

此活动正在调用扩展 AsyncTask 的 DownloadBook.java 类。在 DownloadBook.java 类中,我将 html 作为字符串检索并保存到文件中。保存后,我正在尝试将标题和作者记录到数据库中

public class DownloadBook extends AsyncTask<String, Void, String> {
private Context context;
public DownloadBook(Context context) {
    this.context = context;
}
MyDatabase myDatabase=new MyDatabase(context);//line27
...
myDatabase.addBookInformation(title, author);

为了管理SQLite数据库,我是using android-sqlite-asset-helper库。在库的 github 中,写道: SQLiteAssetHelper 旨在作为框架的 SQLiteOpenHelper 的替代品。 MyDatabase.java

public class MyDatabase extends SQLiteAssetHelper {
   MyDatabase(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);//line21
        setForcedUpgradeVersion(3);
    }
   ...
   public void addBookInformation(String title, String author){
   ...

这会出现以下错误:

03-24 03:13:37.248: E/AndroidRuntime(21237): Caused by:
java.lang.NullPointerException 03-24 03:13:37.248:
E/AndroidRuntime(21237):    at
com.readystatesoftware.sqliteasset.SQLiteAssetHelper.<init>(SQLiteAssetHelper.java:110)
03-24 03:13:37.248: E/AndroidRuntime(21237):    at
com.readystatesoftware.sqliteasset.SQLiteAssetHelper.<init>(SQLiteAssetHelper.java:130)
03-24 03:13:37.248: E/AndroidRuntime(21237):    at
com.joericharduz.akita.MyDatabase.<init>(MyDatabase.java:21) 03-24
03:13:37.248: E/AndroidRuntime(21237):  at
com.joericharduz.akita.DownloadBook.<init>(DownloadBook.java:27) 03-24
03:13:37.248: E/AndroidRuntime(21237):  at
com.joericharduz.akita.AddBook.onCreate(AddBook.java:26)

如何解决这个问题?

【问题讨论】:

    标签: android sqlite android-asynctask sqliteopenhelper


    【解决方案1】:

    在构造函数运行之前初始化成员变量。所以在这里,

    public class DownloadBook extends AsyncTask<String, Void, String> {
        private Context context;
        public DownloadBook(Context context) {
            this.context = context;
        }
        MyDatabase myDatabase=new MyDatabase(context);//line27
    

    ...myDatabase 在构造函数中初始化 context 之前使用 null context 进行初始化。

    new MyDatabase(context) 初始化移动到构造函数。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-12-06
      • 1970-01-01
      • 2018-01-12
      • 1970-01-01
      • 2021-09-13
      • 2011-03-31
      相关资源
      最近更新 更多