cursorwindow数据库并发读写

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呢?

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

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

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

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