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

时间:2012-10-22 09:14:30

标签: android sqlite

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

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;
}

3 个答案:

答案 0 :(得分:2)

是的,建议您在使用该游标对象时关闭游标,以便游标可以在关闭时执行任何保存工作。

答案 1 :(得分:1)

Cursor不是类,而是接口。如果您的Cursor对象来自SQLite查询,那么它是一个SQLiteCursor。在该定义(\Android\android-sdk\source\android\database\sqlite\SQLiteCursor.java)中,close()函数中调用了finalize()。这可能与其他游标类型不同,因为Cursor接口未指定此行为。

答案 2 :(得分:0)

不要关闭数据库。 There is no need(无论如何,数据都会安全地写入持久存储中)。在应用程序启动时打开一次,并在整个应用程序的生命周期内重用相同的连接

请参阅此link