Java에서 디렉토리 트리를 통해 반복
디렉토리 작업 시 일반적인 작업 중 하나는 내부의 모든 파일과 디렉토리를 반복하는 것입니다. 지정된 디렉토리. 여기에는 전체 디렉토리 트리에 대한 포괄적인 액세스를 제공하는 하위 디렉토리가 포함됩니다. Java에는 이 기능을 달성하기 위한 표준 접근 방식이 있습니다.
File#isDirectory():
Java의 File 클래스에는 isDirectory()라는 메서드가 있습니다. 파일이 디렉터리를 나타내는지 아니면 파일을 나타내는지 확인하는 데 사용됩니다. 주어진 파일이 디렉터리인 경우 listFiles() 메서드를 사용하여 얻을 수 있는 파일 및 디렉터리 목록이 포함됩니다.
Files#listFiles()를 사용한 재귀적 접근 방식:
디렉토리 트리를 반복하는 간단한 접근 방식은 재귀를 사용하는 것입니다. 다음 코드 조각은 이 방법을 보여줍니다.
import java.io.File; public class DirectoryIterator { public static void main(String[] args) { File directory = new File("/path/to/dir"); showFiles(directory.listFiles()); } public static void showFiles(File[] files) { for (File file : files) { if (file.isDirectory()) { System.out.println("Directory: " + file.getAbsolutePath()); showFiles(file.listFiles()); // Recursive call } else { System.out.println("File: " + file.getAbsolutePath()); } } } }
이 접근 방식은 listFiles()에서 반환된 파일 목록에 대해 showFiles()를 반복적으로 호출하여 작동합니다. 그러나 디렉터리 트리가 너무 깊어 JVM 스택이 처리할 수 없는 경우 발생할 수 있는 StackOverflowError 예외를 처리하는 것이 중요합니다.
Tail Recursion용 Files#walk():
Java 8 이상의 경우 Files#walk()를 사용하는 것이 더 효율적인 접근 방식입니다. 이 메소드는 JVM 스택이 아닌 메소드 호출 스택에서 반복 상태를 유지함으로써 StackOverflowError 문제를 방지하는 꼬리 재귀를 구현합니다.
import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; public class DirectoryIteratorWithJava8 { public static void main(String[] args) throws Exception { Path directory = Paths.get("/path/to/dir"); Files.walk(directory).forEach(path -> showFile(path.toFile())); } public static void showFile(File file) { if (file.isDirectory()) { System.out.println("Directory: " + file.getAbsolutePath()); } else { System.out.println("File: " + file.getAbsolutePath()); } } }
Files#walk()는 다음을 나타내는 Path 객체의 스트림을 생성합니다. 주어진 디렉토리 트리의 파일과 디렉토리. 그런 다음 forEach() 메서드를 사용하여 각 Path 개체를 처리하고 해당 파일이나 디렉터리를 표시합니다.
위 내용은 Java에서 디렉토리 트리를 어떻게 반복할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!