我正在尝试使用 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/