Java的后臺文件夾下文件的遍歷完整代碼
一、在java中遍歷一個(gè)文件夾里邊的所有文件,可以有兩種方式:
1.遞歸遍歷,通常也是開發(fā)者第一時(shí)間能想到的方法,遞歸遍歷的優(yōu)點(diǎn)是:實(shí)現(xiàn)起來相對簡單,代碼量相對較少,執(zhí)行效率較高,缺點(diǎn)是:比較吃內(nèi)存,對硬件要求較高
// 遞歸遍歷
private void getDirectory(File file) {
File flist[] = file.listFiles();
if (flist == null || flist.length == 0) {
return 0;
}
for (File f : flist) {
if (f.isDirectory()) {
//這里將列出所有的文件夾
System.out.println("Dir==>" + f.getAbsolutePath());
getDirectory(f);
} else {
//這里將列出所有的文件
System.out.println("file==>" + f.getAbsolutePath());
}
}
}
2.非遞歸遍歷,遞歸遍歷的話是很容易理解的,但是非遞歸遍歷的話估計(jì)思路不太容易上來,我當(dāng)時(shí)也苦思良久,發(fā)現(xiàn)java有個(gè)一個(gè)LinkedList這玩意,字面上也大概知道,這個(gè)是用來保存一個(gè)鏈接文件的列表,有這個(gè)的話就好辦了,具體思路是這樣:遍歷一個(gè)文件夾的時(shí)候,如果是文件夾,就添加到linkedlist里去,如果是文件則列出;這樣該目錄的文件和文件夾就遍歷完畢了,文件夾全部被保存到linkedlist里;所以剩下的就是遍歷linkedlist里邊的文件夾的文件,遍歷方式同上邊的操作一致,如果是文件夾就添加到linkedlist里邊(Ps:遍歷過程中的linkedlist始終是同一個(gè)list),當(dāng)然每次從列表取出一個(gè)文件夾之后需要從列表中刪除該文件夾,這里采用linkedlist.removeFirst()來讀取,這樣是每次讀取列表的第一個(gè)元素并將其從列表剔除。這樣只要遍歷到linkedlist的狀態(tài)是isEmty的時(shí)候就說明遍歷完畢了。
// 非遞歸遍歷
private void GetDirectorySize(File file) {
LinkedList list = new LinkedList();
//保存待遍歷文件夾的列表
GetOneDir(file, list);
//調(diào)用遍歷文件夾根目錄文件的方法
File tmp;
while (!list.isEmpty()) {
tmp = (File) list.removeFirst();
//這個(gè)地方的判斷有點(diǎn)多余,但是為了保險(xiǎn)還是給個(gè)判斷了,正常情況列表中是只有文件夾的
//但是不排除特殊情況,例如:本身是文件夾的目標(biāo)在壓入堆棧之后變成了文件
if (tmp.isDirectory()) {
GetOneDirSize(tmp, list);
} else {
System.out.println("file==>" + tmp.getAbsolutePath());
}
}
}
// 遍歷指定文件夾根目錄下的文件
private void GetOneDir(File file , LinkedList list){
//每個(gè)文件夾遍歷都會調(diào)用該方法
System.out.println("Dir==>" + f.getAbsolutePath());
File[] files = file.listFiles();
sumdir += 1;
if (files == null || files.length == 0) {
return ;
}
for (File f : files) {
if (f.isDirectory()) {
list.add(f);
} else {
//這里列出當(dāng)前文件夾根目錄下的所有文件
System.out.println("file==>" + f.getAbsolutePath());
}
}
}
二、用Java遍歷一個(gè)文件夾并獲取它里面的所有內(nèi)容
package demo0823;
import java.io.File;
import java.util.ArrayList;
public class FileTest {
private static ArrayList<String> fileList = new ArrayList<String>();
public static void main(String[] args) {
String filepath = "G:\\Test\\icon";
getFiles(filepath);
}
static void getFiles(String filepath){
File root = new File(filepath);
File[] files = root.listFiles();
for (File file : files){
if(file.isDirectory()){
//如果file是一個(gè)目錄,循環(huán)遞歸調(diào)用地柜
//遞歸調(diào)用
getFiles(file.getAbsolutePath());
fileList.add(file.getAbsolutePath());
System.out.println("顯示"+filepath+"下所有子目錄及其文件"+file.getAbsolutePath());
} else{
//不是目錄的話遍歷其地下的文件
System.out.println("顯示"+filepath+"下所有子文件"+file.getAbsolutePath());
}
}
}
}
效果圖:

總結(jié)
以上就是本文關(guān)于Java的后臺文件夾下文件的遍歷完整代碼的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關(guān)文章
Java查找不重復(fù)無序數(shù)組中是否存在兩個(gè)數(shù)字的和為某個(gè)值
今天小編就為大家分享一篇關(guān)于Java查找不重復(fù)無序數(shù)組中是否存在兩個(gè)數(shù)字的和為某個(gè)值,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01
解決springboot 實(shí)體類String轉(zhuǎn)Date類型的坑
這篇文章主要介紹了解決springboot 實(shí)體類String轉(zhuǎn)Date類型的坑,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
Java多線程執(zhí)行處理業(yè)務(wù)時(shí)間太久解決方法代碼示例
舉例講解Java的Spring框架中AOP程序設(shè)計(jì)方式的使用

