Maison >Java >javaDidacticiel >Comment lister de manière récursive des fichiers en Java à l'aide de « Files.walk » et « Files.find » de Java 8 ?

Comment lister de manière récursive des fichiers en Java à l'aide de « Files.walk » et « Files.find » de Java 8 ?

Susan Sarandon
Susan Sarandonoriginal
2025-01-03 06:44:39768parcourir

How to Recursively List Files in Java Using Java 8's `Files.walk` and `Files.find`?

Comment lister de manière récursive des fichiers en Java à l'aide de Java 8

Introduction

La liste récursive de fichiers est une tâche courante qui implique parcourir les répertoires et sous-répertoires pour récupérer une liste de tous les fichiers dans un chemin spécifié. En Java, il existe plusieurs approches pour y parvenir en utilisant à la fois des bibliothèques intégrées et tierces.

Java 8 (utilisation de Files.walk)

Java 8 introduit un moyen puissant de traiter des fichiers via la méthode Files.walk, qui fournit un flux d'objets Path représentant tous les fichiers d'une arborescence de répertoires. Pour répertorier tous les fichiers normaux dans un répertoire, vous pouvez utiliser le code suivant :

try (Stream<Path> stream = Files.walk(Paths.get(path))) {
    stream.filter(Files::isRegularFile)
          .forEach(System.out::println);
}

Cette approche offre un moyen pratique et simple de parcourir les arborescences de fichiers et d'effectuer des opérations sur des fichiers individuels, telles que l'impression de leurs noms ou effectuer un traitement supplémentaire.

Java 8 (utilisation de Files.find)

Java 8 a également introduit le Méthode Files.find, qui vous permet de rechercher des fichiers en fonction d'un prédicat de filtre. Pour la liste récursive des fichiers, vous pouvez utiliser un filtre pour vérifier les fichiers normaux :

Files.find(Paths.get(path),
           Integer.MAX_VALUE,
           (filePath, fileAttr) -> fileAttr.isRegularFile())
        .forEach(System.out::println);

Bien que Files.find puisse être plus efficace si vous devez filtrer en fonction des attributs de fichier, les performances ne sont pas significatives. différence entre Files.walk et Files.find lors de la simple liste de fichiers normaux.

Comparaison avec d'autres Approches

Les approches basées sur les flux de Java 8 offrent des avantages significatifs par rapport aux implémentations récursives ou hacky traditionnelles. Ils fournissent un moyen concis et expressif de gérer la liste de fichiers récursive, facilitant ainsi la lecture, la maintenance et l'extension de votre code.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn