在我的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的文档.
原文地址:https://codeday.me/bug/20190613/1235453.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。