Подтвердить что ты не робот

Список всех файлов из каталогов и подкаталогов в Java

Каким будет самый быстрый способ перечислить имена файлов из более 1000 каталогов и подкаталогов?

ИЗМЕНИТЬ; Текущий код, который я использую:

import java.io.File;

public class DirectoryReader {

  static int spc_count=-1;

  static void Process(File aFile) {
    spc_count++;
    String spcs = "";
    for (int i = 0; i < spc_count; i++)
      spcs += " ";
    if(aFile.isFile())
      System.out.println(spcs + "[FILE] " + aFile.getName());
    else if (aFile.isDirectory()) {
      System.out.println(spcs + "[DIR] " + aFile.getName());
      File[] listOfFiles = aFile.listFiles();
      if(listOfFiles!=null) {
        for (int i = 0; i < listOfFiles.length; i++)
          Process(listOfFiles[i]);
      } else {
        System.out.println(spcs + " [ACCESS DENIED]");
      }
    }
    spc_count--;
  }

  public static void main(String[] args) {
    String nam = "D:/";
    File aFile = new File(nam);
    Process(aFile);
  }

}
4b9b3361

Ответ 1

Это выглядит отлично (рекурсивно проходит через каталог). Узким местом будет весь файл, который вам нужно сделать, и оптимизация вашей Java не покажет никаких реальных улучшений.

Ответ 2

Как только этот ответ появляется в верхней части Google, я добавляю решение java 7 nio для перечисления всех файлов и каталогов, это занимает примерно на 80% меньше времени на мою систему.

try {
    Path startPath = Paths.get("c:/");
    Files.walkFileTree(startPath, new SimpleFileVisitor<Path>() {
        @Override
        public FileVisitResult preVisitDirectory(Path dir,
                BasicFileAttributes attrs) {
            System.out.println("Dir: " + dir.toString());
            return FileVisitResult.CONTINUE;
        }

        @Override
        public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) {
            System.out.println("File: " + file.toString());    
            return FileVisitResult.CONTINUE;
        }

        @Override
        public FileVisitResult visitFileFailed(Path file, IOException e) {
            return FileVisitResult.CONTINUE;
        }
    });
} catch (IOException e) {
    e.printStackTrace();
}

Ответ 3

Единственное улучшение - избавиться от static spc_count и передать строку spcs в качестве параметра Process.

public static void main(String[] args) {
  String nam = "D:/";
  File aFile = new File(nam);
  Process("", aFile);
}

И при выполнении рекурсивного вызова do

static void Process( String spcs, File aFile) {
  ...
  Process(spcs + " ", listOfFiles[i]);
  ...
}

Таким способом вы можете вызвать этот метод из более чем 1 потока.

Ответ 4

Пока Java 7 не вводит новые классы java.nio.file (например DirectoryStream), боюсь, что у вас уже будет самое быстрое.

Ответ 5

Если вы открыты для использования сторонней библиотеки, проверьте javaxt-core. Он включает многопоточный рекурсивный поиск каталогов, который должен быть быстрее, чем повторение через один каталог за раз. Вот несколько примеров:

http://www.javaxt.com/javaxt-core/io/Directory/Recursive_Directory_Search

Ответ 6

Эй, я написал гораздо более простой код... Попробуйте это... Он покажет каждую папку, подпапки и файлы... int Files=0,Directory=0,HiddenFiles=0,HiddenDirectory=0;

public void listf(String directoryName){

File file=new File(directoryName);

File[] fileList=file.listFiles();

if(fileList!=null){

for(int i=0;i<fileList.length;i++){

if(fileList[i].isHidden()){

if(fileList[i].isFile())

{

System.out.println(fileList[i]);

HiddenFiles++;

}

else{

listf(String.valueOf(fileList[i]));

HiddenDirectory++;

}

}

else if (fileList[i].isFile()) {

//System.out.println(fileList[i]);

Files++;

}

else if(fileList[i].isDirectory()){

Directory++;

listf(String.valueOf(fileList[i]));

}

}

}

}

public void Numbers(){

System.out.println("Files: "+Files+" HiddenFiles: "+HiddenFiles+"Hidden Directories"+HiddenDirectory+" Directories: "+Directory);

}