今天,开发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个原因,写下此文,希望能够给遇到同样问题的猿友帮助。