Android/Java:从多个活动访问相同的SQLite DB对象

JDS*_*JDS 7 java database android class

我的应用程序中有一个中央数据库,需要访问一些不同的活动.

我应该通过使其静态来共享此对象吗?例如,在初始化DB的活动中,我这样做:

protected static appDatabase db;
Run Code Online (Sandbox Code Playgroud)

然后其他人可以通过它访问它FirstActivity.db.

另一种选择是private appDatabase db在每个需要它的活动中创建对象,但我怀疑打开多个数据库对象来访问相同的存储数据可能是浪费.

但是我不太了解java这就是我要问的原因 - 这是什么首选方法,为什么?

谢谢

Mer*_*ert 4

你可以像这样使用单例;

    private static DataHelper singleton;

    public static DataHelper getDataHelper(Context context) {
            if (singleton == null) {
                    singleton = new DataHelper(context);
                    OpenHelper openHelper = new OpenHelper(singleton.context);
                    singleton.db = openHelper.getWritableDatabase();
            }
            if(!singleton.db.isOpen()){
                    OpenHelper openHelper = new OpenHelper(singleton.context);
                    singleton.db = openHelper.getWritableDatabase();
            }
            singleton.context = context;
            return singleton;
    }

    private DataHelper(Context context) {
        this.context = context;
}
Run Code Online (Sandbox Code Playgroud)

并像这样调用你的单例类;

public DataHelper dh;
this.dh = DataHelper.getDataHelper(this);
Run Code Online (Sandbox Code Playgroud)