/*
使用fork/join的异步用法演示不要求返回值
遍历指定的目录,包含了子目录,寻找指定类型的文件
*/
public class FindDirectory {
// public static List<File> fileList = new ArrayList<File>();
/*
不要求返回值的情况
*/
static class MyTask extends RecursiveAction {
File dir;//表示进行查询的目录
public MyTask(File path) {
this.dir = path;
}
@Override
protected void compute() {
ArrayList<MyTask> subTaskLists = new ArrayList<>();
/*
如果是目录,继续进行拆分
*/
if (dir != null) {
if(dir.isDirectory()) {
//所有任务的列表
//展示目录下面的文件
File[] files = dir.listFiles();
//有可能外表是一个目录,但是里面却没有一个文件
if (files!=null) {
for (File file : files) {
MyTask subTask = new MyTask(file);
subTaskLists.add(subTask);
}
if (!subTaskLists.isEmpty()) {
for (MyTask subTaskList : invokeAll(subTaskLists)) {
subTaskList.join();
}
}
}
}else{
//进行筛选
boolean matches = dir.getAbsolutePath().endsWith("txt");//判断是不是txt文件
if (matches) {
System.out.println("文件:"+dir.getName());
}
}
}
}
}
public static void main(String[] args) {
ForkJoinPool pool = new ForkJoinPool();
String path = "D:/";
File file = new File(path);
MyTask myTask = new MyTask(file);
pool.execute(myTask);
myTask.join();
}
}
使用fork/join的异步方式遍历某个目录查找指定文件
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 需求:利用Fork/Join框架来统计某个字符串在某个文件夹的文件中出现的次数。主要用到的技术点:JDK8的Str...
- 我想删掉非docx文件,可以将所有文件都复制到一个目录下,再到此目录下执行删除操作,就可以提取所有docx的文件啦...