您好,登錄后才能下訂單哦!
小編給大家分享一下java如何實(shí)現(xiàn)顯示目錄文件列表和刪除目錄功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
以d:\a目錄為例,假設(shè)D:\a目錄內(nèi)的結(jié)構(gòu)如下:
d:\a |--a.sql |--back.log |--b | |--e | | |--1.txt | | |--2.txt | | `--3.txt | `--f | |--4.txt | |--5.txt | `--6.txt |--c | |--e | | |--ace1.txt | | |--ace2.txt | | `--ace3.txt | `--f | |--4.txt | |--5.txt | `--6.txt `--d |--a.java |--abc (1).txt |--abc (2).txt |--abc (3).txt |--b.java `--c.java
4.1 示例1:列出整個(gè)目錄中的文件(遞歸)
思路:
1.遍歷目錄d:\a。
2.每遍歷到d:\a中的一個(gè)目錄就遍歷這個(gè)子目錄。因此需要判斷每個(gè)遍歷到的元素是否是目錄。
以下是從普通代碼到遞歸代碼前的部分代碼:
File dir = new File("d:/a"); File[] file_list = dir.listFiles(); for (File list : file_list) { if (list.isDirectory()) { File dir_1 = list.listFiles(); //此處開(kāi)始代碼重復(fù),且邏輯上可能會(huì)無(wú)限遞歸下去 if (dir_1.isDirectory()) { .... } } else { System.out.println(list.getAbsolutePath()); } }
對(duì)重復(fù)的代碼部分進(jìn)行封裝,于是使用遞歸方法,既封裝代碼,又解決無(wú)限遞歸問(wèn)題。最終代碼如下:
import java.io.*; public class ListAllFiles { public static void main(String[] args) { File dir = new File("d:/a"); System.out.println("dir------>"+dir.getAbsolutePath()); listAll(dir); } public static void listAll(File dir) { File[] file_list = dir.listFiles(); for (File file : file_list) { if (file.isDirectory()) { System.out.println("dir------>"+file.getAbsolutePath()); listAll(file); } else { System.out.println("file------>"+file.getAbsolutePath()); } } } }
4.2 示例2:列出整個(gè)目錄中的文件(隊(duì)列)
思路:
1.遍歷給定目錄。將遍歷到的目錄名放進(jìn)集合中。
2.對(duì)集合中的每個(gè)目錄元素進(jìn)行遍歷,并將遍歷到的子目錄添加到集合中,最后每遍歷結(jié)束一個(gè)目錄就從集合中刪除它。
3.這樣一來(lái),只要發(fā)現(xiàn)目錄,就會(huì)一直遍歷下去,直到某個(gè)目錄整個(gè)都遍歷完,開(kāi)始遍歷下一個(gè)同級(jí)目錄。
需要考慮的是使用什么樣的集合。首先集合內(nèi)目錄元素?zé)o需排序、不同目錄內(nèi)子目錄名可能重復(fù),因此使用List集合而非set集合,又因?yàn)轭l繁增刪元素,因此使用linkedlist而非arraylist集合,linkedlist集合最突出的特性就是FIFO隊(duì)列。
相比于遞歸遍歷,使用隊(duì)列遍歷目錄的好處是元素放在容器中,它們都在堆內(nèi)存中,不容易內(nèi)存溢出。
import java.util.*; import java.io.*; public class ListAllFiles2 { public static void main(String[] args) { File dir = new File("d:/a"); Queue<File> file_queue = new Queue<File>(); //構(gòu)建一個(gè)隊(duì)列 File[] list = dir.listFiles(); for (File file : list) { //遍歷頂級(jí)目錄 if(file.isDirectory()) { System.out.println("dir------>"+file.getAbsolutePath()); file_queue.add(file); } else { System.out.println("file------>"+file.getAbsolutePath()); } } while (!file_queue.isNull()) { //從二級(jí)子目錄開(kāi)始,逐層遍歷 File subdirs = file_queue.get(); //先取得二級(jí)子目錄名稱 File[] subFiles = subdirs.listFiles(); for (File subdir : subFiles) { //遍歷每個(gè)下一級(jí)子目錄 if(subdir.isDirectory()) { System.out.println("dir------>"+subdir.getAbsolutePath()); file_queue.add(subdir); //如果內(nèi)層還有子目錄,添加到隊(duì)列中 } else { System.out.println("file------>"+subdir.getAbsolutePath()); } } } } } class Queue<E> { private LinkedList<E> linkedlist; Queue() { linkedlist = new LinkedList<E>(); } public void add(E e) { linkedlist.addFirst(e); //先進(jìn) } public E get() { return linkedlist.removeLast(); //先出 } public boolean isNull() { return linkedlist.isEmpty(); } }
4.3 示例3:樹(shù)形結(jié)構(gòu)顯示整個(gè)目錄中的文件(遞歸)
思路:
1.先列出一級(jí)目錄和文件。
2.如果是目錄,則加一個(gè)構(gòu)成樹(shù)形的前綴符號(hào)。然后再遍歷這個(gè)目錄,在此需要遞歸遍歷。
import java.io.*; public class TreeFiles { public static void main(String[] args) { File dir = new File("d:/a"); System.out.println(dir.getName()); listChilds(dir,1); } public static void listChilds(File f,int level) { String prefix = ""; for(int i=0;i<level;i++) { prefix = "| " + prefix; } File[] files = f.listFiles(); for (File file : files) { if(file.isDirectory()) { System.out.println(prefix + file.getName()); listChilds(file,level+1); } else { System.out.println(prefix + file.getName()); } } } }
結(jié)果如下:
a | a.sql | b | | e | | | 1.txt | | | 2.txt | | | 3.txt | | f | | | 4.txt | | | 5.txt | | | 6.txt | back.log | c | | e | | | ace1.txt | | | ace2.txt | | | ace3.txt | | f | | | 4.txt | | | 5.txt | | | 6.txt | d | | a.java | | abc (1).txt | | abc (2).txt | | abc (3).txt | | b.java | | c.java
4.4 刪除整個(gè)目錄
import java.io.*; public class FileDelete { public static void main(String[] args) { File file = new File("d:/a"); rm(file); } public static void rm(File f) { if(!f.exists()){ System.out.println("file not found!"); return; } else if(f.isFile()) { f.delete(); return; } File[] dir = f.listFiles(); for(File file : dir) { rm(file); } f.delete(); } }
以上是“java如何實(shí)現(xiàn)顯示目錄文件列表和刪除目錄功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。