Android:在后台同步远程数据库的最流畅的方法是什么?
作者:互联网
我有一个在Parse托管的Android数据库,我一直在尝试找到最新的方法/做法,用最新的远程更改来更新我的LocalStorage.
我不是要求代码或语法,我只是在寻找一系列要遵循的步骤,我确定我需要使用工作线程,因为我不想阻止用户界面,我很乐意为用户提供尽可能平滑的过渡(他甚至不会意识到更新正在发生)并且我希望它在应用程序位于前台时发生.到目前为止我得到的想法:
>使用多线程(Loopers,Handlers,Thread)并在单独的线程中更新每个表.
>尝试限制请求以最小化CPU使用率并一次获取一个表.
>使用Loader只是听取更改.
>调用IntentService也可以逐表获取.
>创建未绑定服务,并在应用关闭后让数据库更新.
>不要在后台更新数据库,并等到用户实际需要数据并检索它.
我已经尝试过IntentService了,它不像我想的那样顺利:
public class DataService extends IntentService {
public DataService() {
super(DataService.class.getName());
}
@Override
protected void onHandleIntent(Intent intent) {
String[] entities = {
"Img",
"Pack",
"Technology",
"Term",
"TermHierarchy",
"TermImplementation",
"TermTerm",
"UserTechnology",
"UserTerm",
};
for (String entity : entities) {
updateLocalTable(entity);
}
}
private void updateLocalTable(String entity) {
ParseQuery<ParseObject> query = new ParseQuery<ParseObject>(entity);
query.findInBackground(new FindCallback<ParseObject>() {
@Override
public void done(List<ParseObject> objects, ParseException e) {
if (e == null){
ParseObject.pinAllInBackground(objects);
}else {
Log.e(TAG_, e.toString());
}
}
});
}
}
此外,我是第一次发生连接更改(Wi-Fi可用).我是应该只是在onCreate上调用它,还是创建一个Alarm来每隔一定时间更新一次,或者只是在Activity完成时?
我看过一些相关帖子:
Update data in Background Periodically (Android)
Syncronizing Android client with remote SQL-server database, using web service
Send database data through socket connection
sync remote database (mysql) with sqlite database and vice versa
但他们都没有好的和详细的答案,他们并没有真正解决这个问题.
我还要补充一点,Parse处理所有RESTful调用和JSON转换,所以我不必担心.
编辑.
我刚刚在不到2分钟的时间内找到了解释这些概念的视频(并支持@gsgsgs提供的答案):
https://www.youtube.com/watch?v=Expbi0lHLRE
解决方法:
您可以尝试SyncAdapter:
The sync adapter component in your app encapsulates the code for the tasks that transfer data between the device and a server
实现起来并不是很简单,但有一些优点:
>系统调度后台同步与其他网络请求以节省电池
>可由用户在同步设置中配置(禁用或启用后台同步)
>如果请求因exponential backoff失败,适配器将自动重试同步
>您可以简单地将它与您的ContentProvider一起使用
>如果需要,适配器可以在单独的进程中同步
Here一些教程.
标签:database,android,multithreading,parse-com 来源: https://codeday.me/bug/20190523/1156615.html