gpt4 book ai didi

java - 当我回家时不可序列化 SQLiteCursor

转载 作者:行者123 更新时间:2023-12-01 09:37:50 25 4
gpt4 key购买 nike

我的应用程序是一个 RSS 适配器,可与 SQlite、viewpagers 和 RecyclerViews 配合使用。一切正常,但一旦我离开我的应用程序并按主页按钮,我的应用程序就会崩溃并显示以下 logcat:

FATAL EXCEPTION: main
Process: com.herprogramacin.hermosaprogramacion, PID: 14900
java.lang.RuntimeException: Parcelable encountered IOException writing serializable object (name = com.herprogramacin.hermosaprogramacion.UI.Adapters.RVAdapter)
at android.os.Parcel.writeSerializable(Parcel.java:1468)
at android.os.Parcel.writeValue(Parcel.java:1416)
at android.os.Parcel.writeArrayMapInternal(Parcel.java:686)
at android.os.BaseBundle.writeToParcelInner(BaseBundle.java:1330)
at android.os.Bundle.writeToParcel(Bundle.java:1079)
at android.os.Parcel.writeBundle(Parcel.java:711)
at android.support.v4.app.FragmentState.writeToParcel(Fragment.java:137)
at android.os.Parcel.writeTypedArray(Parcel.java:1254)
at android.support.v4.app.FragmentManagerState.writeToParcel(FragmentManager.java:384)
at android.os.Parcel.writeParcelable(Parcel.java:1437)
at android.os.Parcel.writeValue(Parcel.java:1343)
at android.os.Parcel.writeArrayMapInternal(Parcel.java:686)
at android.os.BaseBundle.writeToParcelInner(BaseBundle.java:1330)
at android.os.Bundle.writeToParcel(Bundle.java:1079)
at android.os.Parcel.writeBundle(Parcel.java:711)
at android.app.ActivityManagerProxy.activityStopped(ActivityManagerNative.java:3701)
at android.app.ActivityThread$StopInfo.run(ActivityThread.java:4622)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:158)
at android.app.ActivityThread.main(ActivityThread.java:7224)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)
Caused by: java.io.NotSerializableException: android.database.sqlite.SQLiteCursor
at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1344)
at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1651)
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1497)
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1461)
at java.io.ObjectOutputStream.writeFieldValues(ObjectOutputStream.java:959)
at java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:360)
at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1054)
at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1384)
at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1651)
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1497)
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1461)
at android.os.Parcel.writeSerializable(Parcel.java:1463)
at android.os.Parcel.writeValue(Parcel.java:1416) 
at android.os.Parcel.writeArrayMapInternal(Parcel.java:686) 
at android.os.BaseBundle.writeToParcelInner(BaseBundle.java:1330) 
at android.os.Bundle.writeToParcel(Bundle.java:1079) 
at android.os.Parcel.writeBundle(Parcel.java:711) 
at android.support.v4.app.FragmentState.writeToParcel(Fragment.java:137) 
at android.os.Parcel.writeTypedArray(Parcel.java:1254) 
at android.support.v4.app.FragmentManagerState.writeToParcel(FragmentManager.java:384) 
at android.os.Parcel.writeParcelable(Parcel.java:1437) 
at android.os.Parcel.writeValue(Parcel.java:1343) 
at android.os.Parcel.writeArrayMapInternal(Parcel.java:686) 
at android.os.BaseBundle.writeToParcelInner(BaseBundle.java:1330) 
at android.os.Bundle.writeToParcel(Bundle.java:1079) 
at android.os.Parcel.writeBundle(Parcel.java:711) 
at android.app.ActivityManagerProxy.activityStopped(ActivityManagerNative.java:3701) 
at android.app.ActivityThread$StopInfo.run(ActivityThread.java:4622) 
at android.os.Handler.handleCallback(Handler.java:739) 
at android.os.Handler.dispatchMessage(Handler.java:95) 
at android.os.Looper.loop(Looper.java:158) 
at android.app.ActivityThread.main(ActivityThread.java:7224) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120) 

我们可以在哪里读取“由java.io.NotSerializedException:android.database.sqlite.SQLiteCursor引起”

为什么会发生这种情况?

编辑1:

我的应用程序如何工作。

  1. Main Activity 获取 RSS 的 XML 代码,完成后,MainActivity 获取光标并生成 Recycler View Adapter。

  2. 主要 Activity 创建 viewpager 并向其发送 RecyclerView 适配器。

  3. ViewPager 创建一个新的 Fragment 并将适配器传递给新的 Fragment

  4. 新 fragment 生成 View 并使用 ViewPager 发送给他的数据设置适配器。

我意识到在 MainActivity 中生成适配器并通过 3 个类将其传递给 fragment 是疯狂的。这可能是问题所在吗?

最佳答案

听起来您在 Activity 或其他 View 逻辑中持有对 SQLiteCursor 的引用。当 Android 尝试暂停您的 Activity 时,它会尝试序列化 Activity 当前拥有的数据(以及依赖对象),以便在 Activity 恢复时可以对它们进行反序列化。看看你是如何使用 SQLiteCursor 的,你不应该将它们传递给你的 Activity 或你的 Activity 使用的任何模型对象。

关于java - 当我回家时不可序列化 SQLiteCursor,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38705234/

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