在我的数据库适配器类中,我有很多像这样的方法:
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.finalize()中,Cursor会被关闭并释放其资源吗?否则我必须执行以下操作:
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;
}