在我的数据库适配器类中,我有很多这样的方法:
public long getContactId(final String phoneNumber) throws sqlException { final Cursor cur = mDb.rawQuery( "select contact_id from contactphones where number=? limit 1;",new String[] { phoneNumber }); return cur.movetoFirst() ? cur.getLong(0) : -1; }
我很欣赏这种方法的简洁性.但我不是在调用Cursor.close(),我不确定这是不是问题.是否会关闭Cursor并在Cursor.finalize()中释放其资源?否则我将不得不这样做:
public long getContactId(final String phoneNumber) throws sqlException { final Cursor cur = mDb.rawQuery( "select contact_id from contactphones where number=? limit 1;",new String[] { phoneNumber }); final boolean retVal = cur.movetoFirst() ? cur.getLong(0) : -1; cur.close(); return retVal; }
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。