如何解决Android StrictMode报告误报
| 我一直试图在StrictMode中运行我的应用程序,以检查是否有可能潜行的隐藏问题。我遇到的一个问题是使用ContentResolver时Leaked DatabaseConections的误报。 经过一些实验后,问题简化为以下两行代码:Cursor c = context.getContentResolver().query(MediaStore.Video.Media.EXTERNAL_CONTENT_URI,cols,null,MediaStore.Video.Media.DEFAULT_SORT_ORDER);
c.close()
上面的2行产生以下StrictMode违规:
ERROR/StrictMode(26219): Releasing cursor in a finalizer. Please ensure that you explicitly call close() on your cursor:
ERROR/StrictMode(26219): android.database.sqlite.DatabaSEObjectNotClosedException: Application did not close the cursor or database object that was opened here
ERROR/StrictMode(26219):
at android.database.CursorWindow.<init>(CursorWindow.java:62)
at android.content.ContentProviderProxy.query(ContentProviderNative.java:403)
at android.content.ContentResolver.query(ContentResolver.java:302)
我假设这是特定于该游标由contentProvider返回的事实(因此它不是直接的sqlite游标)。
如果这确实是假阳性或游标泄漏,是否有人有任何见识。
解决方法
我想我可以解释问题出在哪里。
查询数据库时,您会收到异常。因此,将创建一个游标c.close()不会被调用,因为有一个异常。因此,您必须将Cursor的创建置于try catch块中,并在finally块中关闭curson。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。