如何在Android应用程序的整个生命周期中保持全局db4o

时间:2013-03-27 13:38:16

标签: android db4o

我们正在开发一个Android应用程序,它使用db4o在多个活动和服务中存储各种对象。我们正在寻找使用db4o的最佳方法,特别是何时打开和关闭数据库。我们不希望在每次单个存储操作后关闭数据库,并在每次单个检索操作时重新打开它,因为这可能会影响应用程序的速度,因为处理器上的打开和关闭很难。我们更喜欢保持db4o的全局状态,可以在整个应用程序的生命周期中使用。

我在这里读书 global db4o database for multiple activities 将数据库保存在自定义应用程序对象上并在需要时获取实例是个好主意:

public class MyApplication extends Application {
    private volatile ObjectContainer container;
    @Override
    public void onCreate() {
        super.onCreate();
        // the application object is a regular Android context,
        // So you can get the required info`
        this.container = Db4oEmbedded.openFile(...)
    }

    @Override
    public void onTerminate() {
        super.onTerminate();
        // if something was not finished, better rollback
        container.rollback();
        container.close();
    }

    public ObjectContainer database(){
        return container;
    }
}

但是,我意识到应用程序的 onTerminate()方法仅用于仿真目的,并且永远不会在实际的手机上执行。我的问题是,如果onTerminate()从未被调用,我们应该在哪里关闭db对象,这是打开和关闭的最佳策略吗?

1 个答案:

答案 0 :(得分:0)

您可以在应用程序类中创建Lazy load singleton实例,并在Launching Activity的OnCreate方法中初始化(Open)它,并在onDestroy中关闭它。