最近在學C#的文件系統, 發現C#的文件系統貌似比java的東西少一點, 居然連刪除目錄都直接做好封裝了, 想到學java的時候還要自己寫遞歸刪除, 好像沒寫過非遞歸的,就在網上查了下, 關于非遞歸刪除目錄代碼沒幾個, 我就寫了一個,遞歸網上一大堆, 就不粘上來了. 下面是代碼非遞歸的方法:
package demo1; import java.io.File; import java.util.ArrayList; public class Demo1 { /** * 不使用遞歸刪除目錄 * @param args */ public static void main(String[] args) { deleteDirectory("E:\\test"); } public static void deleteDirectory(String rootPath) { //fileList模擬的是一個隊列 ArrayList<File> fileList = new ArrayList<File>();//存儲文件和直接子目錄包含文件的目錄 //directoryList模擬的是一個棧 ArrayList<File> directoryList = new ArrayList<File>();//存儲直接子目錄不包含文件的目錄 File root = new File(rootPath); if(!root.exists()){ System.out.println("您輸入的不是目錄"); return; } if(root.isFile()){ root.delete(); System.out.println("您輸入的是文件,已刪除成功"); return; } fileList.add(0, root);//第一次入隊列 while(fileList.size() > 0) { File dir = fileList.remove(0);//模擬一個出隊列的過程 File[] files = dir.listFiles(); for (int i = 0; i < files.length; i++) { if(files[i].isFile()) files[i].delete(); else fileList.add(files[i]);//模擬一個入隊列的過程 } directoryList.add(dir);//模擬一個壓棧的過程 } //倒序遍歷,模擬一個彈粘的過程 for (int i = directoryList.size() - 1; i >= 0; i--) { directoryList.get(i).delete(); } if(!root.exists()){ System.out.println("您輸入的是文件夾,已刪除成功"); } } }
