码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2014-12-04 14:00:23      阅读:147      评论:0      收藏:0      [点我收藏+]

标签:递归

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

  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. }  


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

标签:递归

原文地址:http://blog.csdn.net/shineflowers/article/details/41723123

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!