使用 SQLite 时,我通常每个应用程序都有一个 SQLiteOpenHelper 实例,并且我从不关闭它,因为它的数据库被许多其他类连续使用,关闭/重新打开它会更慢、更复杂。
现在我正在研究 Realm,并且计划仅从数据访问对象访问 Realm 实例。每个调用都将从工作线程进行。
我一直在阅读这些示例,它们通常为每个活动或后台任务调用 getInstance/close 。由于 Realm 像 SQLite 一样将数据保存在文件中,因此为每个操作调用 getInstance/close 是一个好主意吗?我的意思是,会打电话close
实际上关闭文件连接,从而进行下一个getInstance
打电话慢点?我应该在应用程序级别缓存 Realm 实例并将其注入 DAO 中吗?
Realm 使用引用计数线程本地缓存 + 优化的架构验证。这意味着只要在调用的线程上至少打开一个实例Realm.getInstance()
它只是一个 HashMap 查找。
如果您有一个实例打开any线程中,我们会跳过其他线程上的架构验证,即使它是在那里打开的第一个实例。
如果关闭给定线程上的所有实例,我们将释放线程本地内存,并且需要为该线程上的下一个实例重新分配它。
如果关闭所有线程上的所有实例,您将进行“冷启动”,这是最昂贵的,因为我们需要分配内存+进行架构验证。
最佳实践是只要线程存在,就保持 Realm 实例处于打开状态。对于使用此处描述的模式最容易完成的 UI 线程:https://realm.io/docs/java/latest/#controlling-the-lifecycle-of-realm-instances https://realm.io/docs/java/latest/#controlling-the-lifecycle-of-realm-instances
对于工作线程来说,在开始时打开 Realm 实例并在退出时关闭它是最佳的:
new Thread(new Runnable() {
public void run() {
Realm realm = Realm.getDefaultInstance();
doWork(realm);
realm.close();
}
}).start();
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)