快速列出目录及其所有子目录中的文件

时间:2012-05-02 10:03:46

标签: java io file-listing

我需要查找目录及其所有子目录中的所有文件(除了一些) 目前我正在使用这种方法:

public  static Collection<File> listFiles(File directory,FilenameFilter filter,boolean recurse){
    Vector<File> files = new Vector<File>();
    File[] entries = directory.listFiles();
    if(entries!=null){
        for (File entry : entries){
            if (filter == null || filter.accept(directory, entry.getName())){
                    files.add(entry);
            }

            if (recurse && entry.isDirectory()){
                    files.addAll(listFiles(entry, filter, recurse));
            }
        }
    }
    return files;
}

并像这样使用它:

        this.foundFiles=listFiles(new File(this.BaseDirectory), new FilenameFilter() {
            public boolean accept(File dir, String name) {
                boolean res=true;
                if(name.endsWith(".pdf")){
                    if(!dir.getPath().endsWith("done")){
                        if((workingFile!=null && (dir.getPath().equals(workingFile.getParent()) && name.equals(workingFile.getName())))){
                            res=false;
                        }else{
                            try {
                                ArrayList<String> AuthFolders = DB.getGroupAuthFoldersArray();
                                for(String folder:AuthFolders){
                                    if(dir.getPath().startsWith(BaseDirectory+File.separator+folder)){
                                        res=true;
                                        break;
                                    }else{
                                        res=false;
                                    }
                                }
                            } catch (SQLException ex) {
                                Logger.getLogger(scanner.class.getName()).log(Level.SEVERE, null, ex);
                                res=false;
                            } catch (InterruptedException ex) {
                                Logger.getLogger(scanner.class.getName()).log(Level.SEVERE, null, ex);
                                res=false;
                            }
                        }
                    }else{
                        res=false;
                    }
                }else{
                    res=false;
                }
                return res;
            }
        }, true);

但这太慢了!我在目录中有大约3000个文件,这个方法需要10-15分钟(!!)才能找到它们。

我怎么能快速做到这一点?
我正在考虑使用org.apache.commons.io.FileUtils.listfiles方法。有更快的方法吗?

谢谢

2 个答案:

答案 0 :(得分:9)

在Java 7中使用Files.walkFileTree,它比listFiles更快,因为它使用流式传输。有关详细信息,请阅读tutorial

答案 1 :(得分:1)

} catch (SQLException ex) { 

这不属于打算进行目录列表的类!