Java遍历文件夹的两种方法(非递归和递归)
来源:互联网 发布:阿里云 debian 更换源 编辑:程序博客网 时间:2024/04/29 22:28
import java.io.File;
import java.util.LinkedList;
public class FileSystem {
public static int num;
public static void main(String[] args) {
long a = System.currentTimeMillis();
//String path="c:";
num=0;
String[] lists={"c:","d:"};
/*
for(int i=0;i<lists.length;i++){
File file=new File(lists[i]);
scanDirRecursion(file);
*/
for(int i=0;i<lists.length;i++){
scanDirNoRecursion(lists[i]);
}
System.out.print("文件总数:"+num);
System.out.print("总耗时:");
System.out.println(System.currentTimeMillis() - a);
}
//非递归
public static void scanDirNoRecursion(String path){
LinkedList list = new LinkedList();
File dir = new File(path);
File file[] = dir.listFiles();
for (int i = 0; i < file.length; i++) {
if (file[i].isDirectory())
list.add(file[i]);
else{
System.out.println(file[i].getAbsolutePath());
num++;
}
}
File tmp;
while (!list.isEmpty()) {
tmp = (File)list.removeFirst();//首个目录
if (tmp.isDirectory()) {
file = tmp.listFiles();
if (file == null)
continue;
for (int i = 0; i < file.length; i++) {
if (file[i].isDirectory())
list.add(file[i]);//目录则加入目录列表,关键
else{
System.out.println(file[i]);
num++;
}
}
} else {
System.out.println(tmp);
num++;
}
}
}
//递归
public static void scanDirRecursion(File file) {
try {
if (file.canRead()) {
if (file.isDirectory()) {
String[] files = file.list();
if (files != null) {
for (int i = 0; i < files.length; i++) {
scanDirRecursion(new File(file, files[i]));
}
}
} else {
//if (file.getName().endsWith("ppt"))
System.out.println(file);
num++;
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
测试:
(1)递归: 文件总数:189497 总耗时:39328
(2)非递归:文件总数:189432 总耗时:37469
非递归相对要好
- Java遍历文件夹的两种方法(非递归和递归)
- Java遍历文件夹的两种方法(非递归和递归) .
- Java遍历文件夹的两种方法(非递归和递归)
- Java遍历文件夹的两种方法(非递归和递归) .
- Java遍历文件夹的两种方法(非递归和递归) .
- java遍历文件夹(非递归)
- 递归实现遍历文件夹的两种方法
- 二叉树先序遍历非递归方法的两种实现
- JAVA 遍历文件夹下的所有文件(递归调用和非递归调用)
- JAVA 遍历文件夹下的所有文件(递归调用和非递归调用)
- JAVA 遍历文件夹下的所有文件(递归调用和非递归调用)
- JAVA 遍历文件夹下的所有文件(递归调用和非递归调用)
- JAVA 遍历文件夹下的所有文件(递归调用和非递归调用)
- java 二叉树的递归遍历和非递归遍历
- 非递归遍历文件夹
- 非递归遍历文件夹
- 非递归遍历文件夹
- 非递归遍历文件夹
- 环形队列
- eclipse利用Hibernate Tools生成Hibernate Mapping文件及PO类
- 【转自中华考试网】引用LPSTR、LPCSTR、LPTSTR、LPCTSTR、LPWSTR及LPCWSTR的意义及区别
- win7打开chm文件显示此程序无法显示网页解决办法
- NYOJ,106,背包问题
- Java遍历文件夹的两种方法(非递归和递归)
- PHP基础08-创建Table表格
- 为什么软件开发周期通常是预期的两三倍?
- Java实现文件拷贝的4种方法.
- Cocos2d-x 关于在iOS平台真机测试的一些注意
- android背景选择器selector用法汇总
- Android - Binder机制 - ProcessState和IPCThreadState
- uniGUI中使用Grid++Report设计报表
- 黑马程序员_使用管道流进行两线程间数据交换