尝试调用虚方法' java.lang.Class java.lang.reflect.Field.getType()'在null对象引用上

时间:2014-12-10 19:06:14

标签: java android sqlite orm activeandroid

我在我的Android应用中使用了activeandroid。

在开发过程中运行调试版本时,一切正常。 在创建项目的发布版本后,应用程序现在崩溃了。 这种情况发生在带有Android 5.0的Nexus5以及带有Android 4.4.2的Nexus 7上。

如果您需要查看,请参阅源代码!
https://github.com/MetalMatze/Krautreporter

谢谢!

java.lang.RuntimeException: Unable to create application com.activeandroid.app.Application: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Class java.lang.reflect.Field.getType()' on a null object reference
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4521)
at android.app.ActivityThread.access$1500(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1339)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Class java.lang.reflect.Field.getType()' on a null object reference
at com.activeandroid.e.f.c(Unknown Source)
at com.activeandroid.e.f.c(Unknown Source)
at com.activeandroid.f.c(Unknown Source)
at com.activeandroid.f.onCreate(Unknown Source)
at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:251)
at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:163)
at com.activeandroid.b.b(Unknown Source)
at com.activeandroid.b.a(Unknown Source)
at com.activeandroid.a.a(Unknown Source)
at com.activeandroid.a.a(Unknown Source)
at com.activeandroid.a.a(Unknown Source)
at com.activeandroid.app.Application.onCreate(Unknown Source)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1011)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4518)
... 9 more

1 个答案:

答案 0 :(得分:2)

使用反射按名称查找字段。你的发布版本被Proguard碾压,它将字段重命名为简短而模糊的东西。您需要向Proguard添加例外以保留您使用反射访问的字段名称。

对于如何在此处保留所有或某些类中的字段,已有答案: https://stackoverflow.com/a/23365501/2444099