程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java遍歷文件夾的2種方法

Java遍歷文件夾的2種方法

編輯:關於JAVA

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性能相對好一些。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved