过期数据异常,关闭的游标窗口。

3
我遇到了一个无法解决的错误。
android.database.StaleDataException: Attempting to access a closed CursorWindow.Most probable cause: cursor is deactivated prior to calling this method.
        at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:139)
        at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:50)
        at android.database.CursorWrapper.getString(CursorWrapper.java:118)
        at android.support.v4.widget.SimpleCursorAdapter.bindView(SimpleCursorAdapter.java:135)
        at android.support.v4.widget.CursorAdapter.getView(CursorAdapter.java:256)
        at android.widget.AbsListView.obtainView(AbsListView.java:2435)
        at android.widget.ListView.makeAndAddView(ListView.java:1891)
        at android.widget.ListView.fillDown(ListView.java:792)
        at android.widget.ListView.fillFromTop(ListView.java:853)
        at android.widget.ListView.layoutChildren(ListView.java:1717)
        at android.widget.AbsListView.onLayout(AbsListView.java:2279)
        at android.view.View.layout(View.java:15047)
        at android.view.ViewGroup.layout(ViewGroup.java:4676)
        at android.support.v4.view.ViewPager.onLayout(ViewPager.java:1589)
        at android.view.View.layout(View.java:15047)
        at android.view.ViewGroup.layout(ViewGroup.java:4676)
        at android.widget.RelativeLayout.onLayout(RelativeLayout.java:1055)
        at android.view.View.layout(View.java:15047)
        at android.view.ViewGroup.layout(ViewGroup.java:4676)
        at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1671)
        at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1525)
        at android.widget.LinearLayout.onLayout(LinearLayout.java:1434)
        at android.view.View.layout(View.java:15047)
        at android.view.ViewGroup.layout(ViewGroup.java:4676)
        at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
        at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
        at android.view.View.layout(View.java:15047)
        at android.view.ViewGroup.layout(ViewGroup.java:4676)
        at com.android.internal.widget.ActionBarOverlayLayout.onLayout(ActionBarOverlayLayout.java:374)
        at android.view.View.layout(View.java:15047)
        at android.view.ViewGroup.layout(ViewGroup.java:4676)
        at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
        at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
        at android.view.View.layout(View.java:15047)
        at android.view.ViewGroup.layout(ViewGroup.java:4676)
        at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:2181)
        at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1888)
        at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1095)
        at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6010)
        at android.view.Choreographer$CallbackRecord.run(Choreographer.java:799)
        at android.view.Choreographer.doCallbacks(Choreographer.java:599)
        at android.view.Choreographer.doFrame(Choreographer.java:559)
        at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:784)
        at android.os.Handler.handleCallback(Handler.java:733)
        at android.os.Handler.dispatchMessage(Handler.java:95)
        at android.os.Looper.loop(Looper.java:157)
        at android.app.ActivityThread.main(ActivityThread.java:5872)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:852)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:668)
        at dalvik.system.NativeStart.main(Native Method)

我无法确定问题的来源,因为我的代码中没有任何参考。我有一个viewpager,根据数据库查询显示最多3个listviews。当我从另一个活动更改供给viewpager的数据然后回到它所在的活动时,就会出现上述问题。在onResume中,我重新运行对数据库的查询并重新运行我用来将实际数据放入viewpager页面的加载器。这一切都进行得很顺利,然后它就崩溃了!我不认为问题在于其他活动,因为数据库的更改实际上已经发生并且被保存了。大家有什么想法吗?

发布刷新光标的代码(我假设您正在使用CursorLoader?)还有 - 提供光标的是什么?ContentProvider? - tbm
2个回答

0

这很简单。你在调用 cursor.close(); 操作之后的某个地方仍在使用游标对象。

例如,

String query = "SELECT category FROM table_name where id=" +
                        String.valueOf(0);
Cursor cursor = mDatabase.rawQuery(query, null);

String category_name = cursor.getString(0);
cursor.close();

textView.setText(cursor.getString(0));

你可以通过以下两种方式解决这个问题: 在setText之后使用curser.close()。 或者在setText函数中使用category_name代替cursor.getString(0)。

既然cursor.requery()不起作用,那么稍后调用cursor.close()也不会起作用。在我完成使用它之前,Android会自动关闭游标。为什么?我不知道。 - Ali Kazi

0

看起来 Google 尝试给出了一个答案。他们说你必须重新查询(requery())你的游标以消除 StaleException。但他们也说你不应该再使用 requery()(已弃用),而是要重新打开游标... 我使用了 requery(),问题得到了解决。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接