欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java的后臺(tái)文件夾下文件的遍歷完整代碼

 更新時(shí)間:2017年12月22日 16:30:27   作者:人圭先生  
這篇文章主要介紹了Java的后臺(tái)文件夾下文件的遍歷完整代碼,首先分享了java中遍歷一個(gè)文件夾里邊的所有文件,然后介紹了用Java遍歷一個(gè)文件夾并獲取它里面的所有內(nèi)容詳細(xì)代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下。

一、在java中遍歷一個(gè)文件夾里邊的所有文件,可以有兩種方式:

1.遞歸遍歷,通常也是開發(fā)者第一時(shí)間能想到的方法,遞歸遍歷的優(yōu)點(diǎn)是:實(shí)現(xiàn)起來相對(duì)簡單,代碼量相對(duì)較少,執(zhí)行效率較高,缺點(diǎn)是:比較吃內(nèi)存,對(duì)硬件要求較高

// 遞歸遍歷
 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è)文件夾遍歷都會(huì)調(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的后臺(tái)文件夾下文件的遍歷完整代碼的全部內(nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!

相關(guān)文章

  • Java HashMap底層實(shí)現(xiàn)原理

    Java HashMap底層實(shí)現(xiàn)原理

    HashMap在不同的JDK版本下的實(shí)現(xiàn)是不同的,在JDK1.7時(shí),HashMap 底層是通過數(shù)組+鏈表實(shí)現(xiàn)的;而在JDK1.8時(shí),HashMap底層是通過數(shù)組+鏈表或紅黑樹實(shí)現(xiàn)的,本詳細(xì)介紹了HashMap底層是如何實(shí)現(xiàn)的,需要的朋友可以參考下
    2023-05-05
  • Java多線程執(zhí)行處理業(yè)務(wù)時(shí)間太久解決方法代碼示例

    Java多線程執(zhí)行處理業(yè)務(wù)時(shí)間太久解決方法代碼示例

    這篇文章主要介紹了Java多線程執(zhí)行處理業(yè)務(wù)時(shí)間太久解決方法代碼示例的相關(guān)資料,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • 舉例講解Java的Spring框架中AOP程序設(shè)計(jì)方式的使用

    舉例講解Java的Spring框架中AOP程序設(shè)計(jì)方式的使用

    這篇文章主要介紹了Java的Spring框架中AOP程序設(shè)計(jì)方式的使用講解,文中舉的AOP下拋出異常的例子非常實(shí)用,需要的朋友可以參考下
    2016-04-04
  • SpringBoot中的異步執(zhí)行方法詳解

    SpringBoot中的異步執(zhí)行方法詳解

    這篇文章主要介紹了SpringBoot中的異步執(zhí)行方法詳解,ThreadpoolTaskExecutor不需要手動(dòng)的創(chuàng)建當(dāng)前線程池,但往往我們還是會(huì)手動(dòng)指定,具體原因看源碼就可以自有判斷,需要的朋友可以參考下
    2023-10-10
  • 深入理解Java設(shè)計(jì)模式之組合模式

    深入理解Java設(shè)計(jì)模式之組合模式

    這篇文章主要介紹了JAVA設(shè)計(jì)模式之組合模式的的相關(guān)資料,文中示例代碼非常詳細(xì),供大家參考和學(xué)習(xí),感興趣的朋友可以了解下
    2021-11-11
  • 最新評(píng)論