梦里茶
2015-07-16 13:59
采纳率: 50%
浏览 1.9k

cursorwindow数据库并发读写

现在有一个listview,绑定一个adapter,在adapter里根据position,用cursor去获取数据库中一个表TB的数据,假设表中有200行数据。屏幕可以显示10行listview的item,现在滑到了list底部,这个时候还有一个按钮,按下的时候开启一个新线程1,在这个新线程里删掉了表TB最末尾20行数据,
于是在线程1里用Message传一个消息,
让UI主线程里的handler去更换cursor,调adapter的notifydatasetchanged(),更新listview,

那么问题来了,如果在线程1里,删掉数据后,传递消息前,我向上滑了一下listview
那么这个时候会调用adapter的getview,position为200-10=190,调用cursor的movetoposition(190),然后getString();

此时,cursorwindow里数据只有0-179条数据,但我却请求了第190条数据,会引发一个cursorwindow的异常,大概是can not get row 190 in a cursor window of 180 rows.
要怎么避免这个异常,或者怎么做到及时更新我的cursor或cursorwindow呢?

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • danielinbiti 2015-07-16 15:01
    已采纳

    如果游标方式显示listview,那就不能增删数据,如果有增删数据,那就把数据查出来,放到list或者map中,再通过adapter进行显示。

    打赏 评论
  • HyperionChen 2015-07-16 14:39

    为什么会有这种情况发生,在线程里删掉数据后,马上用handle发送消息到主线程更新,前后就几行代码的执行时间,你可以在这段极其微妙的时间差操作?再说了,既然是在界面上显示的,那么数据就已经读到内存中了,你无论怎么getview都是读的内存数据,只有在调用notifydatasetchanged才会刷新内存呢。

    打赏 评论
  • 「已注销」 2015-07-21 09:46

    要么使用对象锁,要么使用Blockingqueue

    打赏 评论
  • 梦里茶 2015-07-22 05:10

    在执行moveToPosition()或者写DB的操作时都要请求锁吗?

    打赏 评论

相关推荐 更多相似问题