在项目需求中做同步的时候,有时候会有这种设计,
服务器端有统一的可配置的数据, 开启几个线程去服务器请求数据。线程任务完成后,将获取数据存入数据库。
用于界面展示。
每一个线程对应的数据库操作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