在android sqlite中关闭光标的意义是什么?

在android sqlite中关闭光标的意义是什么?,第1张

概述在读取sqlite方法以使用游标读取行时,我了解到从游标检索数据后,我们应该关闭游标以避免任何内存泄漏,但是在这里我怀疑在cursor.getCount下面的代码中()关闭游标后被调用?关闭游标后检索数据不是错误的吗?任何人都可以清除这个疑问!提前致谢!!publicintgetContactsCount(){S

在读取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中关闭光标的意义是什么?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1080327.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-27
下一篇2022-05-27

发表评论

登录后才能评论

评论列表(0条)

    保存