例如我们在进行添加数据A,在A还没结束的时候又开始添加数据B,结果B还没有结束的时候A就先结束了,一般在数据表操作之后就应该关闭数据库,但B在添加数据中呢,而且如果这类型的操作都多个同时进行的情况下应该怎么样去解决,我们可以使用AtomicInteger来计算,先上代码:
private static AtomicInteger mOpenCounter = new AtomicInteger();
private static DataHelper mDatabaseHelper;
private static SQLiteDatabase mDatabase;
public static synchronized void initializeInstance(Context context ) {
if (mDatabaseHelper == null) {
mDatabaseHelper = new DataHelper(context);
}
}
public static synchronized SQLiteDatabase openDatabase() {
if(mOpenCounter .incrementAndGet() == 1) {
// Opening new database
mDatabase = mDatabaseHelper .getWritableDatabase();
}
return mDatabase ;
}
public static synchronized void closeDatabase() {
if(mOpenCounter .decrementAndGet() == 0) {
// Closing database
mDatabase.close();
}
}
使用openDatabase的方法来获取数据库,里面的mOpenCounter.incrementAndGet()会使AtomicInteger的变量value加1,代表着当前有多少个操作正在进行中,使用closeDatabase来关闭数据库,其实不是真的立刻关闭,而是在调用mOpenCounter .decrementAndGet()来使AtomicInteger的变量value减1,如果此时的返回的value的值为0,就代表着所有的操作已经完成了,就可以安心关闭数据库了
代码很简短,却很好用,如果想看看具体怎么样的操作,可以参考我的Kevin笔记:http://pan.baidu.com/s/1o7QFTHK
共同学习,写下你的评论
评论加载中...
作者其他优质文章