Android:我需要关闭Cursor对象吗?

ada*_*ker 8 sqlite android

在我的数据库适配器类中,我有很多这样的方法:

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;
}
Run Code Online (Sandbox Code Playgroud)

我很欣赏这种方法的简洁性.但我不是在调用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;
}
Run Code Online (Sandbox Code Playgroud)

Dal*_*ngh 2

是的,建议您在使用完该游标对象后关闭游标,以便游标可以在关闭时执行它想要执行的任何内务工作。