快速业务通道

Java遍历文件夹的2种方法 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-17

Java遍历文件夹的2种方法

时间:2011-06-01

A.不使用递归的方法:

import java.io.File;
import java.util.LinkedList;
public class FileSystem {
public static void main(String[] args) {
        long a = System.currentTimeMillis();
        LinkedList list = new LinkedList();
        File dir = new File("c:\\Program Files\\Java\\");
        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());
        }
        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].getAbsolutePath());
                }
            } else {
                System.out.println(tmp.getAbsolutePath());
            }
        }
        System.out.println(System.currentTimeMillis() - a);
    }
}

B.使用递归的方法:

import java.io.File;
import java.util.ArrayList;
public class FileSystem{
    private static ArrayList filelist = new ArrayList(); 
    public static void main(String[] args) {
        long a = System.currentTimeMillis();
        refreshFileList("c:\\Program Files\\Java\\");
        System.out.println(System.currentTimeMillis() - a);
    }
    public static void refreshFileList(String strPath) { 
        File dir = new File(strPath); 
        File[] files = dir.listFiles(); 
        if (files == null) 
            return; 
        for (int i = 0; i < files.length; i++) { 
            if (files[i].isDirectory()) { 
                refreshFileList(files[i].getAbsolutePath()); 
            } else { 
                String strFileName = files[i].getAbsolutePath().toLowerCase();
                System.out.println("---"+strFileName);
                filelist.add(files[i].getAbsolutePath());              
            } 
        } 
    }
}

一个方法的方法体实现里再次调用了方法本身,就是递归方法。递归一定要向已知方向递归。

结论:经过测试,使用递归的方法B性能相对好一些。

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号