免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2406 | 回复: 5
打印 上一主题 下一主题

Java中遍历文件夹的2种方法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-11-03 13:41 |只看该作者 |倒序浏览
A.不使用递归:
  1. import java.io.File;
  2. import java.util.LinkedList;
  3. public class FileSystem {
  4.     public static void main(String[] args) {
  5.         
  6.         long a = System.currentTimeMillis();
  7.         
  8.         LinkedList list = new LinkedList();
  9.         File dir = new File("c:\\java\\");
  10.         File file[] = dir.listFiles();
  11.         for (int i = 0; i < file.length; i++) {
  12.             if (file[i].isDirectory())
  13.                 list.add(file[i]);
  14.             else
  15.                 System.out.println(file[i].getAbsolutePath());
  16.         }
  17.         File tmp;
  18.         while (!list.isEmpty()) {
  19.             tmp = list.removeFirst();
  20.             if (tmp.isDirectory()) {
  21.                 file = tmp.listFiles();
  22.                 if (file == null)
  23.                     continue;
  24.                 for (int i = 0; i < file.length; i++) {
  25.                     if (file[i].isDirectory())
  26.                         list.add(file[i]);
  27.                     else
  28.                         System.out.println(file[i].getAbsolutePath());
  29.                 }
  30.             } else {
  31.                 System.out.println(tmp.getAbsolutePath());
  32.             }
  33.         }
  34.         
  35.         System.out.println(System.currentTimeMillis() - a);
  36.     }
  37. }
复制代码
B.使用递归:
  1. import java.io.File;
  2. import java.util.ArrayList;
  3. public class FileSystem1 {
  4.     private static ArrayList filelist = new ArrayList();
  5.    
  6.     public static void main(String[] args) {
  7.         
  8.         long a = System.currentTimeMillis();
  9.         refreshFileList("c:\\java");
  10.         System.out.println(System.currentTimeMillis() - a);
  11.     }
  12.     public static void refreshFileList(String strPath) {
  13.         File dir = new File(strPath);
  14.         File[] files = dir.listFiles();
  15.         
  16.         if (files == null)
  17.             return;
  18.         for (int i = 0; i < files.length; i++) {
  19.             if (files[i].isDirectory()) {
  20.                 refreshFileList(files[i].getAbsolutePath());
  21.             } else {
  22.                 String strFileName = files[i].getAbsolutePath().toLowerCase();
  23.                 System.out.println("---"+strFileName);
  24.                 filelist.add(files[i].getAbsolutePath());                    
  25.             }
  26.         }
  27.     }
  28. }
复制代码

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
2 [报告]
发表于 2010-11-04 12:32 |只看该作者
基本思路都一致。就是要循环处理。

论坛徽章:
0
3 [报告]
发表于 2010-11-07 20:39 |只看该作者
递归好理解一些,不使用递归N多层目录可以都遍历吗?

论坛徽章:
0
4 [报告]
发表于 2010-11-08 15:30 |只看该作者
一般情况下用递归

论坛徽章:
0
5 [报告]
发表于 2010-11-09 14:56 |只看该作者
递归好理解一些,不使用递归N多层目录可以都遍历吗?
surpass_li 发表于 2010-11-07 20:39


可以,list内容是动态的,文件子节点在不停的被加入.
比递归效率要高,因为函数调用是很大的开销.

论坛徽章:
0
6 [报告]
发表于 2010-11-09 16:27 |只看该作者
可以,list内容是动态的,文件子节点在不停的被加入.
比递归效率要高,因为函数调用是很大的开销.
litdong 发表于 2010-11-09 14:56



    明白了,谢谢你:)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP