java顯示目錄文件列表和刪除目錄功能
以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í)子目錄名稱(chēng)
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();
}
}
總結(jié)
以上所述是小編給大家介紹的java顯示目錄文件列表和刪除目錄,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
基于SpringBoot+vue實(shí)現(xiàn)前后端數(shù)據(jù)加解密
這篇文章主要給大家介紹了基于SpringBoot+vue實(shí)現(xiàn)前后端數(shù)據(jù)加解密,文中有詳細(xì)的示例代碼,具有一定的參考價(jià)值,感興趣的小伙伴可以自己動(dòng)手試一試2023-08-08
將本地JAR文件手動(dòng)添加到Maven本地倉(cāng)庫(kù)的實(shí)現(xiàn)過(guò)程
在Java開(kāi)發(fā)中,使用Maven作為項(xiàng)目管理工具已經(jīng)成為了主流的選擇,Maven提供了強(qiáng)大的依賴(lài)管理功能,可以輕松地下載和管理項(xiàng)目所需的庫(kù)和工具,在某些情況下,你可能會(huì)需要將本地下載的JAR文件手動(dòng)添加到Maven的本地倉(cāng)庫(kù)中,這篇博客將詳細(xì)介紹如何實(shí)現(xiàn)這一過(guò)程2024-10-10
JAVA不可變類(lèi)(immutable)機(jī)制與String的不可變性(推薦)
這篇文章主要介紹了JAVA不可變類(lèi)(immutable)機(jī)制與String的不可變性(推薦)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08
Spring實(shí)現(xiàn)三級(jí)緩存機(jī)制
三級(jí)緩存機(jī)制是Spring解決循環(huán)依賴(lài)問(wèn)題的關(guān)鍵,本文主要介紹了Spring實(shí)現(xiàn)三級(jí)緩存機(jī)制,具有一定的參考價(jià)值,感興趣的可以了解一下2025-02-02
Hadoop2.8.1完全分布式環(huán)境搭建過(guò)程
本文搭建了一個(gè)由三節(jié)點(diǎn)(master、slave1、slave2)構(gòu)成的Hadoop完全分布式集群(區(qū)別單節(jié)點(diǎn)偽分布式集群),并通過(guò)Hadoop分布式計(jì)算的一個(gè)示例測(cè)試集群的正確性。對(duì)hadoop分布式環(huán)境搭建過(guò)程感興趣的朋友跟隨小編一起看看吧2019-06-06
Java自定義異常_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Java自定義異常_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理的相關(guān)資料,需要的朋友可以參考下2017-04-04
Java實(shí)現(xiàn)小程序簡(jiǎn)單五子棋
這篇文章主要介紹了利用Java實(shí)現(xiàn)小程序簡(jiǎn)單五子棋,本程序適用于java初學(xué)者鞏固類(lèi)與對(duì)象、事件響應(yīng)、awt包中各種工具的相關(guān)概念以及對(duì)邏輯能力的鍛煉,下面來(lái)看具體實(shí)現(xiàn)吧2021-12-12
Springboot web項(xiàng)目打包實(shí)現(xiàn)過(guò)程解析
這篇文章主要介紹了Springboot web項(xiàng)目打包實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08

