文件操作

上次趨勢科技有一個層次遍歷文件的題目,結果當場沒有做出來,回來在機器上面運行出來了。

應用隊列來實現

 

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);

 }

}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章