我有一个应用程序,我从数据库(greendao)填写listview。我有屏幕方向支持,因此它可以在两个方向上工作。我遇到的问题是,当应用程序是较长时间的背景(当发生这种情况时无法找到某些特定点)并且我回到它时,listview是空的,如果我尝试做任何事情它会崩溃。
我有一个不可能的时间调试这个,因为只有当应用程序在后台运行一段时间才会发生。
我通过从数据库填充arraylist然后将其发送到适配器来填充listview。
有谁知道为什么会这样?
编辑: 广播收发问题解决了
但仍未找到列表视图为空的原因。
我有另一个logcat tho(问题是从数据库获取数据:/):
11-11 13:45:31.136: E/AndroidRuntime(4468): FATAL EXCEPTION: main
11-11 13:45:31.136: E/AndroidRuntime(4468): java.lang.NullPointerException
11-11 13:45:31.136: E/AndroidRuntime(4468): at si.comtron.tronpos.content.DatabaseHelpers.viewArticleWithPrice(DatabaseHelpers.java:70)
11-11 13:45:31.136: E/AndroidRuntime(4468): at si.comtron.tronpos.ArticlesFragment.onCreateView(ArticlesFragment.java:269)
11-11 13:45:31.136: E/AndroidRuntime(4468): at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:831)
11-11 13:45:31.136: E/AndroidRuntime(4468): at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1037)
11-11 13:45:31.136: E/AndroidRuntime(4468): at android.app.BackStackRecord.run(BackStackRecord.java:635)
11-11 13:45:31.136: E/AndroidRuntime(4468): at android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1399)
11-11 13:45:31.136: E/AndroidRuntime(4468): at android.app.FragmentManagerImpl$1.run(FragmentManager.java:428)
11-11 13:45:31.136: E/AndroidRuntime(4468): at android.os.Handler.handleCallback(Handler.java:615)
11-11 13:45:31.136: E/AndroidRuntime(4468): at android.os.Handler.dispatchMessage(Handler.java:92)
11-11 13:45:31.136: E/AndroidRuntime(4468): at android.os.Looper.loop(Looper.java:155)
11-11 13:45:31.136: E/AndroidRuntime(4468): at android.app.ActivityThread.main(ActivityThread.java:5511)
11-11 13:45:31.136: E/AndroidRuntime(4468): at java.lang.reflect.Method.invokeNative(Native Method)
11-11 13:45:31.136: E/AndroidRuntime(4468): at java.lang.reflect.Method.invoke(Method.java:511)
11-11 13:45:31.136: E/AndroidRuntime(4468): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1029)
11-11 13:45:31.136: E/AndroidRuntime(4468): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:796)
11-11 13:45:31.136: E/AndroidRuntime(4468): at dalvik.system.NativeStart.main(Native Method)
答案 0 :(得分:1)
转到手机上的Developer Options
,然后选中Don't save Activities
复选框。这样,你的任何Activities
一旦被置于后台就会被杀死,你很可能会在不等待的情况下重新创建问题。
答案 1 :(得分:1)
最初在这里注册的IntentReceiver si.comtron.tronpos.USB.USBService$1@4197ac28。你是否错过了对unregisterReceiver()的调用?
您似乎正在使用BroadcastReceiver
在onPause()
注销您的接收器:
@Override
protected void onPause() {
super.onPause();
unregisterReceiver(yourReceiver);
}
答案 2 :(得分:0)
有谁知道为什么会这样?
由于内存不足,您的应用程序进程已终止,但它仍然存在于最近任务列表中。当您尝试返回应用程序时,Android会为您分配一个全新的进程,并启动您上次执行的最后一个活动...并且您假设此过程中的其他内容应该已经存在,当它不存在时。
答案 3 :(得分:0)
您可以创建一个包含所有数据的文件,在活动的OnCreate中,您应该检查您的变量是否有数据。如果没有,您可以从之前保存的文件中提取数据。