【问题标题】:openOrCreateDatabase doesn't workopenOrCreateDatabase 不起作用
【发布时间】:2012-03-06 18:48:22
【问题描述】:

我需要帮助。 我有一个带有自定义适配器的 ListView,当在这个 ListView 中我有一个 CheckBox 并且在 onClick 方法中应该更新我的数据库中的一个表时。 我的 CheckBox 的 onClick 方法是在我的适配器类中实现的,当我单击某个 CheckBox 时,我会在创建 ListView 时调用其他类的方法。

在我的适配器类中

#
chkQuitado.setOnClickListener(new View.OnClickListener() {
@Override
  public void onClick(View v) {
    CheckBox cb = (CheckBox) v;
    ViewMovimentos vm = new ViewMovimentos();

    int movId = Integer.parseInt(entry.getMovId());
    if(cb.isChecked()){
     vm.confirmaQuitacao(context, movId); //Implementada na classe ViewMovimentos
    }else{
     vm.desfazQuitacao(context, movId); //Implementada na classe ViewMovimentos
   }
  }
});
#

在我的 Movimentos.class 中,我实现了我的方法 confirmaQuitacao() 和 desfazQuitacao()

#
public void confirmaQuitacao(Context context, final int movId){
   AlertDialog.Builder builder = new AlertDialog.Builder(context);
   builder.setMessage("Confirma a quitação deste movimento?");
   builder.setPositiveButton("Sim", new DialogInterface.OnClickListener() {
   @Override
    public void onClick(DialogInterface dialog, int which) {
       quitaMovimento(movId, MOV_FECHADO);
   }
});
builder.setNeutralButton("Não", null);


builder.setTitle("Aviso");
builder.show();
}

public void desfazQuitacao(Context context, final int movId){
   AlertDialog.Builder builder = new AlertDialog.Builder(context);
    builder.setMessage("Deseja marcar esse movimento como não quitado?");
    builder.setPositiveButton("Sim", new DialogInterface.OnClickListener() {
   @Override
    public void onClick(DialogInterface dialog, int which) {
     quitaMovimento(movId, MOV_ABERTO);
    }
});
builder.setNeutralButton("Não", null);


builder.setTitle("Aviso");
builder.show();
}
#

当这两个方法调用quitaMovimento方法时。

#
public void quitaMovimento(int movId, int quitar){
   SQLiteDatabase banco = openOrCreateDatabase(nmBanco, MODE_WORLD_WRITEABLE, null);

   ContentValues camposPar = new ContentValues();
   camposPar.put("movQuitado", quitar);
   banco.update("movimentos", camposPar, "movId = "+movId, null);

   localizaRegistros();
}
#

所以,当我调用 openOrCreateDatabase() 时,我的应用程序会强制关闭,并且 logcat 会显示以下错误。

#
02-14 22:47:33.645: E/AndroidRuntime(367): Uncaught handler: thread main exiting due to uncaught exception
02-14 22:47:33.749: E/AndroidRuntime(367): java.lang.NullPointerException
02-14 22:47:33.749: E/AndroidRuntime(367): at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:193)
02-14 22:47:33.749: E/AndroidRuntime(367): at com.simpatico.sgf.ViewMovimentos.quitaMovimento(ViewMovimentos.java:433)
02-14 22:47:33.749: E/AndroidRuntime(367): at com.simpatico.sgf.ViewMovimentos$7.onClick(ViewMovimentos.java:450)
02-14 22:47:33.749: E/AndroidRuntime(367): at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:158)
02-14 22:47:33.749: E/AndroidRuntime(367): at android.os.Handler.dispatchMessage(Handler.java:99)
02-14 22:47:33.749: E/AndroidRuntime(367): at android.os.Looper.loop(Looper.java:123)
02-14 22:47:33.749: E/AndroidRuntime(367): at android.app.ActivityThread.main(ActivityThread.java:4363)
02-14 22:47:33.749: E/AndroidRuntime(367): at java.lang.reflect.Method.invokeNative(Native Method)
02-14 22:47:33.749: E/AndroidRuntime(367): at java.lang.reflect.Method.invoke(Method.java:521)
02-14 22:47:33.749: E/AndroidRuntime(367): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
02-14 22:47:33.749: E/AndroidRuntime(367): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
02-14 22:47:33.749: E/AndroidRuntime(367): at dalvik.system.NativeStart.main(Native Method)
#

有人可以帮我解决这个问题吗?

谢谢

【问题讨论】:

  • 如您所见,NullPointerException 表示您提供了错误的参数或您的 ContextWrapper 为空。您的 DB 类是否扩展了 SQLiteDatabase 类?也许你应该使用openOrCreateDatabase (String path, SQLiteDatabase.CursorFactory factory) 而不是openOrCreateDatabase (String path, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
  • 抱歉,您的西班牙语代码不可读。你应该用英文写。对其他人进行调试将是最容易的。
  • nmBanco 是一个包含我的数据库名称的变量
  • 你有没有尝试使用没有ErrorHandler的其他方法?
  • 正如我写的没有 ErrorHandler 参数的 openOrCreateDatabase (String path, SQLiteDatabase.CursorFactory factory)

标签: android database nullpointerexception


【解决方案1】:

openOrCreateDatabase 的一些参数被记录为可选,但这并不意味着您可以为这些参数传递null;这意味着您应该在根本不传递这些参数的情况下使用重载。

这是一种适合您的语法:

SQLiteDatabase banco = openDatabase(nmBanco, MODE_WORLD_WRITEABLE, SQLiteDatabase.CREATE_IF_NECESSARY)

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-09-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多