android开发问题:Attempted to access a cursor after it has been closed.

今天,开发android项目中遇到了一个很奇怪的问题。


问题:项目由一个页面跳转到另一个程序(比如按home键),再回到这个程序,就会奔溃。

有错误提示:Attempted to access a cursor after it has been closed.

问题奇怪的地方有,这个问题在android2.2版本下没有,到了4.0版本以上时就出现了。


自己想了一段时间,实在是想不到哪里有错误,最后在网上找到了答案。

是因为查询数据库时用到了以下函数:

Cursor cusor = activity.managedQuery(uri, projection, "address like ?",new String[]{ strsql },"date desc");

并在之后调用了cusor.close(); 关闭游标,但是android 4.0系统会关闭游标,不用自己手动的去关闭,所以就出现了这个奇怪的问题。


解决的办法是:

原来的代码:

Cursor cusor = activity.managedQuery(uri, projection, "address like ?",new String[]{ strsql },"date desc");

换成了以下代码:

ContentResolver cr = activity.getContentResolver();

Cursor cusor = cr.query(uri, projection, "address like ?",new String[]{ strsql },"date desc");


猿友们也有提供另一种方法,游标不要关闭。

但程序中其他的地方都是用了游标就关闭,这个地方就不关闭,总觉得怪怪的(不知道是不是强迫症)。


还有猿友说,managedQuery会阻塞主线程,已经不推荐使用。


1、觉得这个问题很奇怪。

2、managedQuery会阻塞主线程,已经不推荐使用,想找时间研究研究。

3、项找时间研究研究这个解决办法的原理。

基于以上3个原因,写下此文,希望能够给遇到同样问题的猿友帮助。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值