递归与非递归遍历文件目录

递归遍历目录的缺点:遇到多层级目录时,层级越多,堆栈的负荷越大。

  1. import java.io.File;  
  2. import java.util.LinkedList;  
  3.   
  4. /* 
  5.  * 采用非递归方式遍历目录及其子目录的文件   
  6.  */  
  7. public class ProcessDirectory {  
  8.     public static int num;//文件总量  
  9.       
  10.     public static void main(String[] args) {  
  11.         String path = "/Users/Jackie/Downloads/temp";  
  12. //      scanDirNoRecursion(path);  
  13.           
  14.         scanDirRecursion(new File(path));  
  15.         System.out.println(path + "目录下共有文件数量为:" + num);  
  16.     }  
  17.       
  18.     // 非递归  
  19.     public static void scanDirNoRecursion(String path) {  
  20.         LinkedList list = new LinkedList();  
  21.         File file = new File(path);  
  22.         if (file.isFile()) {  
  23.             System.out.println(file.getAbsolutePath());  
  24.             num++;  
  25.             return;  
  26.         }  
  27.         list.add(file); //是目录则添加进链表  
  28.         while (!list.isEmpty()) { //如果不为空  
  29.             File f = (File) list.removeFirst();  //先进先出,取出首个文件目录对象并且移除
  30.             File[] listFiles = f.listFiles();  
  31.             if (listFiles == null) {  
  32.                 return;  
  33.             }  
  34.             int length = listFiles.length;  
  35.             for (int i = 0; i < length; i++) {  
  36.                 if (listFiles[i].isDirectory()) {  
  37.                     list.add(listFiles[i]);  
  38.                 } else {  
  39.                     System.out.println(listFiles[i].getAbsolutePath());  
  40.                     num++;  
  41.                 }  
  42.             }  
  43.         }  
  44.         System.out.println(path + "目录下共有文件数量为:" + num);  
  45.     }  
  46.       
  47.     //递归  
  48.     public static void scanDirRecursion(File file) {  
  49.         if (file.isFile()) {  
  50.             System.out.println(file.getAbsolutePath());  
  51.             num++;  
  52.             return;  
  53.         }  
  54.         File[] listFiles = file.listFiles();  
  55.         int length = listFiles.length;  
  56.         for (int i = 0; i < length; i++) {  
  57.             scanDirRecursion(listFiles[i]);  
  58.         }  
  59.     }  
  60. }  


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值