蜂窝和光标(沮丧)

时间:2011-05-30 00:33:36

标签: android cursor android-3.0-honeycomb

我将此活动完全转换为使用蜂窝。我重新设计了所有游标管理以使用新的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

3 个答案:

答案 0 :(得分: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及早期版本上正常运行。

答案 1 :(得分:5)

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

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

所以我的解决方案是:

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

到现在为止,我再也无法重现异常。

答案 2 :(得分:3)

这是Honeycomb对游标管理方式所做的一些更改的影响。以前,如果您多次调用startManagingCursor所有内容继续正常工作,现在它将导致IllegalStateException,因为该活动正在尝试重新查询已关闭的游标。解决方案是在再次调用startManagingCursor之前关闭旧游标(就像交换游标时一样)。

所以ParentActivity由于Activity内托管游标生命周期而间接执行此操作。

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

您可以在此处看到对此的一些讨论:http://groups.google.com/group/android-developers/browse_thread/thread/658133bec901d7e