文件操作

上次趋势科技有一个层次遍历文件的题目,结果当场没有做出来,回来在机器上面运行出来了。

应用队列来实现

 

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

 }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值