Question :
Les développeurs rencontrent souvent le besoin de lister les fichiers dans un répertoire et triez-les en fonction de leur date de dernière modification. Une approche consiste à utiliser File.listFiles() et à trier la liste à l'aide de File.lastModified(). Cependant, existe-t-il une méthode plus efficace ?
Réponse :
L'approche la plus optimale consiste à exploiter un comparateur personnalisé en conjonction avec Arrays.sort().
File[] files = directory.listFiles(); Arrays.sort(files, new Comparator<File>() { public int compare(File f1, File f2) { return Long.valueOf(f1.lastModified()).compareTo(f2.lastModified()); } });
Cette approche garantit que les fichiers sont triés par ordre chronologique, les fichiers les plus anciens apparaissant en premier. L'expression Long.valueOf(f1.lastModified()) convertit l'horodatage en un horodatage long, qui est ensuite comparé à l'aide de compareTo(). En utilisant l'interface Comparator, les fichiers sont triés avec élégance sans avoir besoin de classes d'assistance supplémentaires.
Il est crucial de noter que File.listFiles() ne garantit pas l'ordre des fichiers renvoyés. Par conséquent, il est nécessaire de trier explicitement le tableau à l'aide du comparateur fourni.
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!