0

API 10 を使用してエミュレーター Nexus S Platform 2.3.3 で Android アプリを実行すると、次のエラーが発生します。API 18 を使用して Nexus 4 Android 4.3 で正常に動作します。

コード:

 public class AppController extends Application {

     [...]

     private static AppDatabase mDbo;

     [...]
     try {
         // Here comes the crash, it crashes immediately, i cannot step into 
         mDbo = new AppDatabase( AppDatabase.NAME,null, new AppSQLiteCursor(),AppDatabase.VERSION) ;

      }
  }

エラー スタック トレース:

12-14 23:04:01.996    1372-1372/com.example.myapp E/APP_ERROR﹕ VerifyError raised!
    java.lang.VerifyError: com.example.myapp.database.AppDatabase
            at com.example.myapp.AppController.onCreate(AppController.java:85)
            at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:969)
            at android.app.ActivityThread.handleBindApplication(ActivityThread.java:3272)
            at android.app.ActivityThread.access$2200(ActivityThread.java:117)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:969)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:130)
            at android.app.ActivityThread.main(ActivityThread.java:3683)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:507)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
            at dalvik.system.NativeStart.main(Native Method)
4

1 に答える 1

6

最後に、VerifyError 例外の原因を突き止めました。これは、API 11 まで含まれていなかった SQLiteCantOpenDatabaseException が原因でした。AppDatabase クラスのエラーをキャッチするために SQLiteException のみを使用すると、うまくいきました。

于 2013-12-18T02:22:18.537 に答える