应用程序在后台长时间丢失数据

时间:2014-11-11 11:57:25

标签: android android-activity android-fragments android-lifecycle android-background

我有一个应用程序,我从数据库(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)

4 个答案:

答案 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中,您应该检查您的变量是否有数据。如果没有,您可以从之前保存的文件中提取数据。