
在读取sqlite方法以使用游标读取行时,我了解到从游标检索数据后,我们应该关闭游标以避免任何内存泄漏,但是在这里我怀疑在cursor.getCount下面的代码中()关闭游标后被调用?关闭游标后检索数据不是错误的吗?
任何人都可以清除这个疑问!
提前致谢!!
public int getContactsCount() { String countquery = "SELECT * FROM " + table_CONTACTS; sqliteDatabase db = this.getReadableDatabase(); Cursor cursor = db.rawquery(countquery, null); cursor.close(); // return count return cursor.getCount();}解决方法:
这是SQLiteCursor#close()的源代码:
@OverrIDe public voID close() { super.close(); synchronized (this) { mquery.close(); mDriver.cursorClosed(); } }这是SQLiteCursor#getCount()的源代码:
@OverrIDe public int getCount() { if (mCount == NO_COUNT) { fillWindow(0); } return mCount;}如您所见,行计数似乎存储在变量mCount中,并且在关闭游标时不会重置此值.从效率的角度来看,这可能是有道理的,因为它省去了不必要清除状态的需要.
因此看来,在关闭游标后获取计数确实可以,但是您可能不应该依赖它,因为Javadoc不提供此类保证,此行为以后可能会更改.
总结以上是内存溢出为你收集整理的在android sqlite中关闭光标的意义是什么?全部内容,希望文章能够帮你解决在android sqlite中关闭光标的意义是什么?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)