加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Sqlite事务正在阻止Android ui

发布时间:2020-12-12 18:55:32 所属栏目:百科 来源:网络整理
导读:在我的 Android应用程序中,运行相对较长的AsyncTask我正在运行以在应用程序启动时更新数据库.如果用户在任务完成之前退出应用程序,我需要将其包装在事务中以回滚.但是,由于在事务中包装代码,因此阻止了ui,直到任务完成.为什么会这样,因为代码已经在一个单独
在我的 Android应用程序中,运行相对较长的AsyncTask我正在运行以在应用程序启动时更新数据库.如果用户在任务完成之前退出应用程序,我需要将其包装在事务中以回滚.但是,由于在事务中包装代码,因此阻止了ui,直到任务完成.为什么会这样,因为代码已经在一个单独的线程中运行了?

我正在使用ORMLite,这基本上是事务的包装,更新db的代码进入call()..,在添加代码以更新事务中的db之前没有锁定ui …

public ConnectionSource source; 
@Override
protected Boolean doInBackground(Context... params) {
    try {
        TransactionManager.callInTransaction(source,new Callable<Void>() {
            public Void call() throws Exception {
                return null;
            }
        });

解决方法

不幸的是,SQLite事务是独占的,它们阻止所有其他数据库活动.我怀疑即使你在另一个线程,UI线程正在做某种数据库活动,必须等待事务完成.

>这是一个related question.
>这是关于SQLite transaction levels的文档.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读