上次趨勢科技有一個層次遍歷文件的題目,結果當場沒有做出來,回來在機器上面運行出來了。
應用隊列來實現
import java.io.File;
import java.util.LinkedList;
import java.util.Queue;
//層次遍歷file的目錄結構,打印輸出全部的目錄名稱
public class FileNames {
public static void getFileNames(String dir) {
Queue<File> q = new LinkedList<File>();
File f = new File(dir);
q.add(f);
while (!q.isEmpty()) {
File ff = (File) q.poll();
System.out.println(ff.getName());
if (ff.isDirectory()) {
String[] list = ff.list();
for (int i = 0; i < list.length; i++) {
String dirr = dir + File.separator + list[i];
getFileNames(dirr);
}
}
}
}
public static void main(String[] args) {
String dir = "G:" + File.separator + "j2ee";//起始的目錄名稱
getFileNames(dir);
}
}
以前還做一個簡單一點的。計算目錄下的文件個數。用深度優先來完成
import java.io.File;
//計算文件目錄下面的文件數目
public class FileCounts {
private int count = 0;
public int fileCount(String direct) {
File fDir = new File(direct);
String[] fi = fDir.list();
for (int i = 0; i < fi.length; i++) {
fi[i] = direct + "//" + fi[i];
File ff = new File(fi[i]);
if (ff.isFile()) {
count++;
System.out.println(count);
} else if (ff.isDirectory()) {
fileCount(fi[i]);
}
}
return count;
}
public static void main(String[] args) {
String dir = "G:"+File.separator+"temp";
FileCounts fc = new FileCounts();
int k = fc.fileCount(dir);
System.out.println(k);
}
}