Ответ 1
Это выглядит отлично (рекурсивно проходит через каталог). Узким местом будет весь файл, который вам нужно сделать, и оптимизация вашей 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);
}
}
Это выглядит отлично (рекурсивно проходит через каталог). Узким местом будет весь файл, который вам нужно сделать, и оптимизация вашей Java не покажет никаких реальных улучшений.
Как только этот ответ появляется в верхней части 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();
}
Единственное улучшение - избавиться от 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 потока.
Пока Java 7 не вводит новые классы java.nio.file (например DirectoryStream
), боюсь, что у вас уже будет самое быстрое.
Если вы открыты для использования сторонней библиотеки, проверьте javaxt-core. Он включает многопоточный рекурсивный поиск каталогов, который должен быть быстрее, чем повторение через один каталог за раз. Вот несколько примеров:
http://www.javaxt.com/javaxt-core/io/Directory/Recursive_Directory_Search
Эй, я написал гораздо более простой код... Попробуйте это... Он покажет каждую папку, подпапки и файлы...
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);
}