gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 20:58:34 25 4
gpt4 key购买 nike

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

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

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

有人知道为什么会这样吗?

编辑:广播接收问题解决

但是仍然没有找到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)

最佳答案

IntentReceiver si.comtron.tronpos.USB.USBService$1@4197ac28 that was originally registered here. Are you missing a call to unregisterReceiver()?

看来你正在使用 BroadcastReceiver

onPause() 中取消注册您的接收器:

@Override
protected void onPause() {
super.onPause();
unregisterReceiver(yourReceiver);
}

关于android - 应用程序长时间在后台丢失数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26864358/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com