我收到来自Google的随机NullPointerException崩溃报告无法复制。我正在使用对扩展OrmLiteSqliteOpenHelper的类的静态引用。辅助器在主类中初始化,扩展了SherlockFragmentActivity。
if (DatabaseHelper.getInstance() == null) {
DatabaseHelper.setInstance(this.getApplicationContext());
}
首先,我可能会在设备旋转或发送到后台时发生。但是没有多少测试能够重现这个问题。
代码中没有任何地方将静态mHelper变量设置为null
public class DatabaseHelper extends OrmLiteSqliteOpenHelper {
…
private static DatabaseHelper mHelper;
…
public static DatabaseHelper getInstance() {
return DatabaseHelper.mHelper;
}
public static void setInstance(Context context) {
DatabaseHelper.mHelper = new DatabaseHelper(context);
}
…
}
有没有人知道可能导致这种情况的原因?
以下是其中一份报告:
java.lang.RuntimeException: Unable to start activity ComponentInfo{au.com.dcbs.tradies/au.com.dcbs.tradies.presentation.document.DocumentActivity}: java.lang.NullPointerException
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2049)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2083)
at android.app.ActivityThread.access$600(ActivityThread.java:134)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1233)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4697)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:787)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:554)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at bd.a(Document.java:654)
at au.com.dcbs.tradies.presentation.document.DocumentActivity$a.b(DocumentActivity.java:102)
at au.com.dcbs.tradies.presentation.document.DocumentActivity$a.onActivityCreated(DocumentActivity.java:78)
at e.a(FragmentManager.java:891)
at e.a(FragmentManager.java:1080)
at e.a(FragmentManager.java:1062)
at e.k(FragmentManager.java:1810)
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:501)
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1133)
at android.app.Activity.performStart(Activity.java:4549)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2022)
... 11 more
第654行是此方法的第一行:
public static Document get(long id, Context context) {
DocumentEntity entity = DatabaseHelper.getInstance().getDocumentDao().queryForId((int)id);
Document doc = new Document(entity, context);
return doc;
}
getDocumentDao返回类型为com.j256.ormlite.dao.RuntimeExceptionDao
答案 0 :(得分:2)
如果您发布问题所在的代码
会有所帮助at bd.a(Document.java:654)
但是作为可能解决您的问题的一般建议,您可以考虑在application
类中初始化数据库帮助程序,而不是在任何活动中,因为它似乎是用于整个应用程序的东西,并且不依赖于具体的活动背景。
修改强>
我认为您需要在第654行中断代码,因为很难判断哪个函数返回null。 e.g。
DatabaseHelper helper = DatabaseHelper.getInstance();
...
答案 1 :(得分:2)
在Android中,它不能确保不会始终保留静态字段变量,您应该......
public static DatabaseHelper getInstance(Context context) {
if (mHelper == null) {
mHelper = new DatabaseHelper(context);
}
return mHelper;
}