在项目需求中做同步的时候,有时候会有这种设计,
服务器端有统一的可配置的数据, 开启几个线程去服务器请求数据。线程任务完成后,将获取数据存入数据库。
用于界面展示。
每一个线程对应的数据库操作ok后,再发请求去服务端获取手机唯一id 对应的用户的自定义数据。
每一个线程都获取数据ok,触发一个事件。如弹出对话框,然后告诉用户服务端有数据,是否同步。
这种需求可以用事务处理的方法来做。
一,如果执行的事务的数目确定的情况下,可用:
1.变量计数法。
一共n个线程。每完成一个线程任务,count++ ,当count == n 的时候,触发事件。
2.容器计数法。
每开始一个线程任务,容器中加入一个线程id,
每完成一个线程任务,容器中删除对应的线程id,
当容器为空 的时候,触发事件。
二,如果执行的事务的数目不确定的情况下,可用:
守护线程遍历的办法:
每开始一个线程任务,AtomicLong mTaskCounter = new AtomicLong(); 计数加一。执行完成后计数减一。
当守护线程 mTaskCounter 为0 时, 不在阻塞。执行finish action。
public void startScan(ArrayList<String> paths) {
try {
for (String path : paths) {
scanDir(path);//多线程执行
}
while (mTaskCounter.get() > 0) {
Thread.sleep(100);
}
//do finish action
} catch (Exception ex) {
ex.printStackTrace();
}
}
多线程 扫描 文件 demo :
https://github.com/javalive09/ScanSdCardDemo/tree/master/app/src/main/java/peter/util/scandemo
本文探讨了在项目需求中通过多线程从服务器获取数据,并将其存储到数据库的方法。详细介绍了如何使用变量计数法和容器计数法来确保线程操作的同步性,以及在数据获取完成后触发事件的流程。此外,还提供了一个多线程扫描文件的实例,并解释了如何使用守护线程遍历和AtomicLong计数器来管理不确定性数量的任务。
1015

被折叠的 条评论
为什么被折叠?



