Java中遍歷指定路徑下的文件夾查找出文件並打印出路徑

方式一、直接遍歷

import java.io.File;
import java.util.LinkedList;

public class FileSystemWithoutRecurisive {
    public static void main(String[] args) {
        long a = System.currentTimeMillis();
        LinkedList list = new LinkedList();
        File dir = new File("F:\\bjsxt_msb_hibernate");
        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);
    }
}

方式二、遞歸

import java.io.File;
import java.util.ArrayList;

public class ListFileSystemUseRecurisive {
    private static ArrayList filelist = new ArrayList();

    public static void main(String[] args) {
        long a = System.currentTimeMillis();
        refreshFileList("F:\\bjsxt_msb_hibernate");
        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性能相對好一些。 //78ms

原文地址:https://www.cnblogs.com/alamps/archive/2012/07/25/2607943.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章