d:\a ディレクトリを例として、D:\a ディレクトリの構造が次のようになっていると仮定します:
d:\a |--a.sql |--back.log |--b | |--e | | |--1.txt | | |--2.txt | | `--3.txt | `--f | |--4.txt | |--5.txt | `--6.txt |--c | |--e | | |--ace1.txt | | |--ace2.txt | | `--ace3.txt | `--f | |--4.txt | |--5.txt | `--6.txt `--d |--a.java |--abc (1).txt |--abc (2).txt |--abc (3).txt |--b.java `--c.java
4.1 例 1: ディレクトリ全体のファイルを一覧表示します。 (再帰的)
アイデア:
1. ディレクトリ d:\a を走査します。
2. d:\a のディレクトリがトラバースされるたびに、このサブディレクトリもトラバースされます。したがって、走査された各要素がディレクトリであるかどうかを判断する必要があります。
以下は、通常のコードから再帰的コードに移行する前のコードの一部です:
File dir = new File("d:/a"); File[] file_list = dir.listFiles(); for (File list : file_list) { if (list.isDirectory()) { File dir_1 = list.listFiles(); //此处开始代码重复,且逻辑上可能会无限递归下去 if (dir_1.isDirectory()) { .... } } else { System.out.println(list.getAbsolutePath()); } }
繰り返されるコード部分をカプセル化するには、再帰的メソッドが使用されます。これは、コードをカプセル化するだけでなく、無限再帰の問題も解決します。最終的なコードは次のとおりです。
import java.io.*; public class ListAllFiles { public static void main(String[] args) { File dir = new File("d:/a"); System.out.println("dir------>"+dir.getAbsolutePath()); listAll(dir); } public static void listAll(File dir) { File[] file_list = dir.listFiles(); for (File file : file_list) { if (file.isDirectory()) { System.out.println("dir------>"+file.getAbsolutePath()); listAll(file); } else { System.out.println("file------>"+file.getAbsolutePath()); } } } }
4.2 例 2: ディレクトリ全体のファイル (キュー) を一覧表示する
#アイデア:
1. 指定されたディレクトリを移動します。走査したディレクトリ名をコレクションに追加します。
2. コレクション内の各ディレクトリ要素を走査し、走査したサブディレクトリをコレクションに追加します。最後に、走査が終了するたびに、コレクションからディレクトリを削除します。
3. このようにして、ディレクトリが見つかる限り、特定のディレクトリを通過するまでそのディレクトリの走査が継続され、その後、同じレベルの次のディレクトリが走査されます。
考慮する必要があるのは、どのような種類のコレクションを使用するかです。まず、コレクション内のディレクトリ要素は並べ替える必要がなく、異なるディレクトリのサブディレクトリ名が重複する可能性があるため、セット コレクションの代わりに List コレクションが使用されます。要素は頻繁に追加および削除されるため、リンクリストが使用されます。配列リスト コレクションの代わりにリンクリスト コレクションの最も顕著な機能は FIFO キューです。
再帰的走査と比較して、キューを使用してディレクトリを走査する利点は、要素がコンテナ内に配置され、要素がすべてヒープ メモリ内にあり、メモリ オーバーフローが起こりにくいことです。
import java.util.*; import java.io.*; public class ListAllFiles2 { public static void main(String[] args) { File dir = new File("d:/a"); Queue<File> file_queue = new Queue<File>(); //构建一个队列 File[] list = dir.listFiles(); for (File file : list) { //遍历顶级目录 if(file.isDirectory()) { System.out.println("dir------>"+file.getAbsolutePath()); file_queue.add(file); } else { System.out.println("file------>"+file.getAbsolutePath()); } } while (!file_queue.isNull()) { //从二级子目录开始,逐层遍历 File subdirs = file_queue.get(); //先取得二级子目录名称 File[] subFiles = subdirs.listFiles(); for (File subdir : subFiles) { //遍历每个下一级子目录 if(subdir.isDirectory()) { System.out.println("dir------>"+subdir.getAbsolutePath()); file_queue.add(subdir); //如果内层还有子目录,添加到队列中 } else { System.out.println("file------>"+subdir.getAbsolutePath()); } } } } } class Queue<E> { private LinkedList<E> linkedlist; Queue() { linkedlist = new LinkedList<E>(); } public void add(E e) { linkedlist.addFirst(e); //先进 } public E get() { return linkedlist.removeLast(); //先出 } public boolean isNull() { return linkedlist.isEmpty(); } }
4.3 例 3: ツリー構造でディレクトリ全体のファイルが (再帰的に) 表示される
#アイデア:1. まず、第 1 レベルのディレクトリとファイルをリストします。 2. ディレクトリの場合は、ツリー状の接頭記号を追加します。次に、このディレクトリを走査します。これには再帰的な走査が必要です。import java.io.*; public class TreeFiles { public static void main(String[] args) { File dir = new File("d:/a"); System.out.println(dir.getName()); listChilds(dir,1); } public static void listChilds(File f,int level) { String prefix = ""; for(int i=0;i<level;i++) { prefix = "| " + prefix; } File[] files = f.listFiles(); for (File file : files) { if(file.isDirectory()) { System.out.println(prefix + file.getName()); listChilds(file,level+1); } else { System.out.println(prefix + file.getName()); } } } }
a | a.sql | b | | e | | | 1.txt | | | 2.txt | | | 3.txt | | f | | | 4.txt | | | 5.txt | | | 6.txt | back.log | c | | e | | | ace1.txt | | | ace2.txt | | | ace3.txt | | f | | | 4.txt | | | 5.txt | | | 6.txt | d | | a.java | | abc (1).txt | | abc (2).txt | | abc (3).txt | | b.java | | c.java
4.4 ディレクトリ全体を削除します
import java.io.*; public class FileDelete { public static void main(String[] args) { File file = new File("d:/a"); rm(file); } public static void rm(File f) { if(!f.exists()){ System.out.println("file not found!"); return; } else if(f.isFile()) { f.delete(); return; } File[] dir = f.listFiles(); for(File file : dir) { rm(file); } f.delete(); } }
以上がJavaでディレクトリファイル一覧表示とディレクトリ削除機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。