gpt4 book ai didi

android - 可以在应用程序类中创建 ORMLite 数据库助手吗?

转载 作者:可可西里 更新时间:2023-11-01 18:47:41 24 4
gpt4 key购买 nike

我正在尝试使用 ORMLite 包创建一个 android 应用程序。我有一些 Activity 和服务,也使用 https://github.com/tomquist/Android-Error-Reporter能够从客户的掌上电脑接收错误信息。 ORMLite 要求所有 Activity 和服务扩展 OrmLiteBaseActivity 等或向每个 Activity 添加适当的代码,以便能够获取数据库助手并在 Activity 完成后释放它。所以将此代码添加到每个 Activity 或服务并不是很方便。我还有一些可以使用数据库的辅助类

我还有一个包含一些全局信息和方法的应用程序类。所以我决定在应用程序类中打开 ormlite 助手,并在所有 Activity/类中使用它,如下所示:

public class MyApplication extends Application {
private volatile DatabaseHelper databaseHelper = null;

@Override
public void onCreate() {
super.onCreate();
}

@Override
public void onTerminate() {
if (databaseHelper != null) {
OpenHelperManager.releaseHelper();
databaseHelper = null;
}
super.onTerminate();
}

public DatabaseHelper getHelper() {
if (databaseHelper == null) {
databaseHelper = OpenHelperManager.getHelper(this, DatabaseHelper.class);
}
return databaseHelper;
}
}

并以这种方式在其他类中使用它:

((MyApplication) getApplicationContext()).getHelper();

您认为以这种方式使用它是个好主意,还是会出现一些内存泄漏或其他问题?我担心的是 onTerminate 永远不会在真实设备上运行......我正处于“尝试新事物”的阶段,所以想听听对此的任何评论,以消除我将来可能因错误的方法而没有遇到的问题重写代码。

最佳答案

整体机制看起来不错@Alex 但据我所知,onTerminate() 仅用于 emulated environments所以用处不大。当程序在真实设备上终止时,您的程序会被 Android 操作系统杀死,因此没有理由担心内存泄漏等问题。

您的代码最重要的是它保证了单个 databaseHelper 实例。每个实例都有自己的数据库连接,当在程序中打开一 (1) 个以上的数据库连接时,就会出现问题。 Sqlite 可以处理同时使用同一个连接的多个线程,但它不能很好地处理多个连接,并且可能会出现数据不一致的情况。

关于android - 可以在应用程序类中创建 ORMLite 数据库助手吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8208992/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com