成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

java怎么實(shí)現(xiàn)顯示目錄文件列表和刪除目錄功能

本篇內(nèi)容主要講解“java怎么實(shí)現(xiàn)顯示目錄文件列表和刪除目錄功能”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“java怎么實(shí)現(xiàn)顯示目錄文件列表和刪除目錄功能”吧!

成都創(chuàng)新互聯(lián)公司主營(yíng)昌邑網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶App定制開發(fā),昌邑h5微信平臺(tái)小程序開發(fā)搭建,昌邑網(wǎng)站營(yíng)銷推廣歡迎昌邑等地區(qū)企業(yè)咨詢

以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(); //此處開始代碼重復(fù),且邏輯上可能會(huì)無限遞歸下去
 if (dir_1.isDirectory()) {
  ....
 }
 } else {
 System.out.println(list.getAbsolutePath());
 }
}

對(duì)重復(fù)的代碼部分進(jì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.這樣一來,只要發(fā)現(xiàn)目錄,就會(huì)一直遍歷下去,直到某個(gè)目錄整個(gè)都遍歷完,開始遍歷下一個(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í)子目錄開始,逐層遍歷
  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:樹形結(jié)構(gòu)顯示整個(gè)目錄中的文件(遞歸)

思路:

1.先列出一級(jí)目錄和文件。

2.如果是目錄,則加一個(gè)構(gòu)成樹形的前綴符號(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();
 }
}

到此,相信大家對(duì)“java怎么實(shí)現(xiàn)顯示目錄文件列表和刪除目錄功能”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

網(wǎng)站欄目:java怎么實(shí)現(xiàn)顯示目錄文件列表和刪除目錄功能
URL網(wǎng)址:http://jinyejixie.com/article44/jjphee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、響應(yīng)式網(wǎng)站、網(wǎng)站內(nèi)鏈、域名注冊(cè)用戶體驗(yàn)、做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計(jì)
巴马| 衡阳市| 广东省| 厦门市| 浏阳市| 崇礼县| 宁夏| 揭阳市| 蒙自县| 铜川市| 阿勒泰市| 台东市| 宁乡县| 肇州县| 酉阳| 章丘市| 玉屏| 乐陵市| 买车| 建宁县| 宣威市| 邯郸市| 儋州市| 广平县| 法库县| 潜江市| 岑巩县| 沧源| 金山区| 兖州市| 博乐市| 密山市| 景德镇市| 腾冲县| 大理市| 泾源县| 罗平县| 来宾市| 安溪县| 延庆县| 白水县|