1

我有一个应用程序,我从数据库(greendao)填充列表视图。我有屏幕方向支持,所以它可以在两个方向上工作。我遇到的问题是,当应用程序长时间处于后台时(当这种情况发生时找不到某个特定点)并且我回到它时,列表视图是空的,如果我尝试做任何事情它会崩溃。

我无法调试它,因为它仅在应用程序在后台运行一段时间时才会发生。

我通过从数据库中填充一个数组列表然后将其发送到适配器来填充列表视图。

有谁知道为什么会这样?

编辑:广播接收器问题已解决

但是仍然没有找到listviews为空的原因。

我有另一个 logcat 寿(问题是从数据库获取数据:/):

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

4 回答 4

1

转到Developer Options您的手机并选中复选框Don't save Activities。这样一来,您的任何人Activities都会在后台被杀死,并且您很可能无需等待即可重新创建问题。

于 2014-11-11T11:59:51.887 回答
1

最初在这里注册的 IntentReceiver si.comtron.tronpos.USB.USBService$1@4197ac28。您是否错过了对 unregisterReceiver() 的调用?

看来你正在使用BroadcastReceiver

注销您的接收器onPause()

@Override
protected void onPause() {
    super.onPause();
    unregisterReceiver(yourReceiver);
}
于 2014-11-11T12:32:33.220 回答
0

有谁知道为什么会这样?

由于内存不足,您的应用进程已终止,但它仍存在于最近的任务列表中。当您尝试返回应用程序时,Android 会为您创建一个新进程并启动您正在进行的最后一个活动......并且您假设该进程中的其他内容应该已经存在,而实际上并非如此。

于 2014-11-11T12:13:59.427 回答
0

您可以创建一个包含所有数据的文件,在您的活动的 OnCreate 中,您应该检查您的变量是否有数据。如果没有,您可以从之前保存的文件中提取数据。

于 2014-11-11T13:07:46.540 回答