4

我有这个活动完全转换为使用蜂窝。我重新设计了所有游标管理以使用新的 cursorLoader。一切都适用于所有其他操作系统版本(使用兼容性库),但仍然不适用于蜂窝。以下堆栈跟踪非常难以理解,因为它没有告诉我哪个游标或哪一行失败。此外,在调试时,ParentActivity 中的任何代码行都不会被执行。当我恢复 ParentActivity 时发生此错误。当我开始活动时效果很好,但在返回时失败。

05-29 17:23:32.978: ERROR/AndroidRuntime(31692): FATAL EXCEPTION: main
05-29 17:23:32.978: ERROR/AndroidRuntime(31692): java.lang.RuntimeException: Unable to resume activity {com.xxx.xxx/com.xxx.xxx.ParentActivity}: java.lang.IllegalStateException: trying to requery an already closed cursor
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2227)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2255)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1028)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at android.os.Looper.loop(Looper.java:132)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at android.app.ActivityThread.main(ActivityThread.java:4025)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at java.lang.reflect.Method.invokeNative(Native Method)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at java.lang.reflect.Method.invoke(Method.java:491)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at dalvik.system.NativeStart.main(Native Method)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692): Caused by: java.lang.IllegalStateException: trying to requery an already closed cursor
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at android.app.Activity.performRestart(Activity.java:4394)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at android.app.Activity.performResume(Activity.java:4420)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2217)
05-29 17:23:32.978: ERROR/AndroidRuntime(31692):     ... 10 more
4

3 回答 3

11

我遇到了同样的问题。这是我所做的。在我称为 startManagingCursor 的所有活动中,我将其覆盖为:

@Override
public void startManagingCursor(Cursor c) {

    // To solve the following error for honeycomb:
    // java.lang.RuntimeException: Unable to resume activity 
    // java.lang.IllegalStateException: trying to requery an already closed cursor
    if (Build.VERSION.SDK_INT < VersionUtil.HONEYCOMB) {
        super.startManagingCursor(c);
    }
}

这使我的应用程序可以在 Honeycomb 和早期版本上正确运行。

于 2011-06-09T23:26:22.773 回答
5

我遇到了同样的问题,并认为我可能已经找到了问题并进行了“干净”的修复。(我认为完全停止管理游标不是一个好主意)

我在一些活动中使用了 Adapter.changeCursor,这些活动在除蜂窝之外的所有版本中都运行良好。changeCursor 方法关闭旧游标,但显然不会停止管理该游标。所以活动继续管理已经关闭的旧游标。在重新启动活动时,它会尝试重新查询它,而不检查它是否已关闭。

所以我的解决方案是:

Cursor oldCursor = mAdapter.getCursor();
mAdapter.changeCursor(newCursor);
stopManagingCursor(oldCursor);

直到现在我无法再次重现异常。

于 2011-07-05T08:04:10.907 回答
3

这是 Honeycomb 中对游标管理方式所做的一些更改的效果。以前如果你startManagingCursor不止一次调用一切都继续正常工作,现在它会导致一个IllegalStateException因为活动试图重新查询一个关闭的游标。解决方案是在再次调用之前关闭旧游标startManagingCursor(就像交换游标时一样)。

因此ParentActivity,由于Activity.

现在您提到您正在使用 ACL 和 CursorLoader,请确保在更改游标时调用swapCursor(Cursor c),这应该可以解决您的问题。

你可以在这里看到一些讨论:http ://groups.google.com/group/android-developers/browse_thread/thread/658133bec901d7e

于 2011-05-30T00:52:49.033 回答