我怀疑sqlbrite是否自动关闭光标,因为我一直得到:
dalvik.system.CloseGuard.open(CloseGuard.java:180) at android.database.sqlite.SQLiteDatabase.openInner(SQLiteDatabase.java:809) at android.database.sqlite.SQLiteDatabase.open(SQLiteDatabase.java:793)上未调用java.lang.Throwable的显式终止方法“close”
但是我在文档中没有看到任何关于我应该被明确称为cursor.close的声明。
编辑1
下面是给我提供光标而不是关闭错误的代码片段:
DbProvider.db(getActivity()).createQuery(Item.NAME, sqlQuery, selectionArgs).mapToList(new Func1<Cursor, ItemEntity>() {
@Override
public ItemEntity call(Cursor cursor) {
return new ItemEntity(cursor);
}
}).subscribe(itemEntities -> {
Debug.info(this, "items " + itemEntities );
}, Throwable::printStackTrace, () -> {});发布于 2017-04-21 01:12:50
如果您正在调用query.run()并获得一个游标,则需要手动关闭它。如果您正在使用mapToList/mapToOne api,则不需要手动关闭它。
https://stackoverflow.com/questions/43531921
复制相似问题