java -- File類和遞歸

来源:https://www.cnblogs.com/paopaoT/archive/2023/04/16/17323917.html
-Advertisement-
Play Games

File類 java.io.File 類是文件和目錄路徑名的抽象表示,主要用於文件和目錄的創建、查找和刪除等操作。File類將文件,文件夾和路徑封裝成了對象,提供大量的方法來操作這些對象。 靜態常量 // 靜態常量 static String pathSeparator // 與系統有關的路徑分隔符 ...


File類

java.io.File 類是文件和目錄路徑名的抽象表示,主要用於文件和目錄的創建、查找和刪除等操作。File類將文件,文件夾和路徑封裝成了對象,提供大量的方法來操作這些對象。

靜態常量

// 靜態常量
static String pathSeparator // 與系統有關的路徑分隔符
	// Window操作系統,分隔符是分號;
	// Linux操作系統,分隔符是冒號:
static String separator // 與系統有關的名稱分隔符
	// Window操作系統,名稱分割符號為 \
	// Linux操作系統,名稱分隔符號為 /

絕對路徑和相對路徑

  • 絕對路徑:從盤符(Windows)或"/"(Linux)開始的路徑,這是一個完整的路徑,絕對路徑具有唯一性
  • 相對路徑:相對於某個目錄的路徑,這是一個便捷的路徑,開發中經常使用,java中寫的相對路徑, 一般都是相對於當前項目
// Windows絕對路徑 Windows
String path1 = "E:\\study\\java\\5_projects\\FileClass\\test";
String path2 = "/opt/html/dist"
// 相對路徑
String path3 = "FileClass\\test";

構造方法

public File(String pathname)
// 通過將給定的路徑名字元串轉換為抽象路徑名來創建新的 File實例
public File(String parent, String child)
// 從父路徑名字元串和子路徑名字元串創建新的 File實例
public File(File parent, String child)
// 從父抽象路徑名和子路徑名字元串創建新的 File實例
// 根據給定的路徑 創建File對象
File file1 = new File("E:\\study\\java\\5_projects\\FileClass\\test");
System.out.println(file1.toString() + "\t " + file1.getPath());
// 傳入字元串的父路徑 和 字元串的子路徑 創建File對象
File file2 = new File("E:\\study\\java\\5_projects\\FileClass","test");
System.out.println(file2);
File file3 = new File("E:\\study\\java\\5_projects","\\FileClass\\test");
System.out.println(file3);
// 傳入File類型的父路徑 和 字元串類型的子路徑
File file4 = new File(file1, "1.txt");
System.out.println(file4);

註意:

  1. 一個File對象代表硬碟中實際存在的一個文件或者目錄。
  2. 無論該路徑下是否存在文件或者目錄,都不影響File對象的創建。

獲取某些屬性

public File getAbsoluteFile() // 獲取絕對路徑(File類型)
public String getAbsolutePath() // 獲取絕對路徑(字元串類型)
public String getPath() // 返回字元串類型的路徑
public String getName() // 獲取文件名
public long length() // 獲取文件位元組數, 不存在返回0
public File getParentFile() //返回File類型的父路徑
public long lastModified() // 返回最後修改時間
// 獲取絕對路徑(字元串類型)
System.out.println("絕對路徑為: " + new File("FileClas\\src").getAbsoluteFile());
System.out.println(file4.getAbsolutePath());
// 獲取絕對路徑(File類型)
System.out.println(file4.getAbsoluteFile());
// 獲取相對路徑下的File對象
File file6 = new File("FileClass" + File.separator + "test" + File.separator + "2.txt");
System.out.println(file6.getAbsolutePath());

// 獲取字元串類型的路徑 直接打引結果相同
// 直接列印(toString)調用了getPath方法
System.out.println(file1.getPath());

// 獲取文件名
System.out.println(new File("FileClass/test/1.txt").getName());

// 獲取文件位元組數, 不存在返回0
long fileLength = new File("FileClass/test/1.txt").length();
System.out.println(fileLength);

// 獲取父路徑, 返回File對象
File parentFile = new File("FileClass/test/1.txt").getParentFile();
System.out.println(parentFile);
System.out.println(parentFile.getParentFile());

// 獲取最後修改時間
long lastModifyTime = new File("FileClass/test/1.txt").lastModified();
System.out.println(lastModifyTime + "\t" + new Date(lastModifyTime));

判斷的方法

public boolean exists()
// 判斷路徑是否存在, 存在返回true

public boolean isFile()
// 判斷是否為文件 文件返回true, 目錄返回false, 路徑不存在也返回false

public boolean isDirectory()
// 判斷是否為目錄, 目錄返回true, 文件返回false, 路徑不存在也返回false
// 判斷路徑是否存在, 存在返回true
System.out.println(new File("FileClass/test/NewDir1").exists());

// 判斷是否為文件 文件返回true, 目錄返回false, 路徑不存在也返回false
System.out.println(file6.isFile());

// 判斷是否為目錄, 目錄返回true, 文件返回false, 路徑不存在也返回false
System.out.println(new File("FileClass/test/NewDir1").isDirectory());

// 因此 判斷某文件是文件/文件夾時 要先判斷路徑是否存在
if (file1.exists()) {
    if(file1.isFile()) {
        System.out.println("文件");
    } else {
        System.out.println("目錄");
    }
} else {
    System.out.println("文件不存在");
}

創建和刪除文件

public boolean createNewFile() throws IOException
// 創建文件, 成功返回true, 存在則不創建
public boolean mkdir()
// 創建單級目錄, 成功返回true, 存在則不創建
public boolean mkdirs()
// 創建單/多級目錄, 成功返回true, 存在則不創建
public boolean delete()
// 刪除文件或空目錄, 成功返回true
// 創建文件, 成功返回true, 失敗返回false
System.out.println(file6.createNewFile());

// 創建目錄, 成功返回true, 失敗返回false
System.out.println(new File("FileClass/test/NewDir1").mkdir());
System.out.println(new File("FileClass/test/NewDir2/NewDir3/NewDir4").mkdirs());

// 刪除文件 和 空目錄
System.out.println(file6.delete());
System.out.println(new File("FileClass/test/NewDir1").delete());

// 創建目錄
//StringBuilder sb = new StringBuilder("FileClass/test/");
//for (int i = 0; i < 200; i++) {
//    sb.append(i);
//    sb.append("/");
//}
//System.out.println(new File(sb.toString()).mkdirs());
//
//刪除目錄
//File fileForDel = new File(sb.toString());
//do {
//    try {
//        if (Integer.parseInt(fileForDel.getName()) < 0) {
//            System.out.println("刪除失敗");
//            return;
//        }
//    } catch (NumberFormatException e) {
//        return;
//    }
//    fileForDel.delete();
//    fileForDel = fileForDel.getParentFile();
//} while (true);

遍歷目錄

public String[] list()
// 返回目錄下所有文件 存放在字元串數組中

public File[] listFiles()
// 返回目錄下所有文件 存放在File數組中
String[] arr = new File("FileClass/test").list();
for (String s : arr) {
    System.out.println(s);
}

File[] fileArr = new File("FileClass/test").listFiles();
for (File file : fileArr) {
    System.out.println(file + "\t" + file.getName());
}

FileFilter介面

文件過濾器介面,此介面的實現類可以傳遞給方法listFiles(),實現文件的過濾功能
public boolean accept(File path):方法參數就是listFiles()方法獲取到的文件或者目錄的路徑。如果方法返回true,表示需要此路徑,否則此路徑將被忽略。

File dir = new File(".\\ConcurrentProgramming\\src\\_5_ThreadPool");
File[] files = dir.listFiles(new FileFilter() {
    @Override
    public boolean accept(File pathname) {
        //判斷如果獲取到的是目錄,直接放行
        if(pathname.isDirectory())
            return true;
        //獲取路徑中的文件名,判斷是否java結尾,是就返回true
        return pathname.getName().toLowerCase().endsWith("java");
    }
});
for(File file : files){
    System.out.println(file);
}

遞歸

指在當前方法內調用自己的這種現象。

public static void a(){
    a();
}

遞歸求和

計算1 ~ n的和

分析:num的累和 = num + (num-1)的累和,所以可以把累和的操作定義成一個方法,遞歸調用。

實現代碼:

public static void main(String[] args) {
    //計算1~num的和,使用遞歸完成
    int num = 5;
    // 調用求和的方法
    int sum = getSum(num);
    // 輸出結果
    System.out.println(sum);

}
public static int getSum(int num) {
    /*
    num為1時,方法返回1,
    相當於是方法的出口,num總有是1的情況
    */
    if(num == 1){
    	return 1;
    }
    /*
    num不為1時,方法返回 num +(num-1)的累和
    遞歸調用getSum方法
    */
    return num + getSum(num-1);
}

遞歸求階乘

階乘:所有小於及等於該數的正整數的積。

分析:n的階乘:n! = n * (n-1) ... 3 * 2 * 1

//計算n的階乘,使用遞歸完成
public static void main(String[] args) {
    int n = 3;
    // 調用求階乘的方法
    int value = getValue(n);
    // 輸出結果
    System.out.println("階乘為:"+ value);
}

public static int getValue(int n) {
    // 1的階乘為1
    if (n == 1) {
    	return 1;
}
    /*
    n不為1時,方法返回 n! = n*(n-1)!
    遞歸調用getValue方法
    */
    return n * getValue(n - 1);
}

目錄遍歷

遍歷目錄下的所有文件和所有的子目錄。

分析:目錄遍歷,無法判斷多少級目錄,所以在遍歷需要進行判斷,如果遍歷到的還是目錄,就要使用遞歸,遍歷所有目錄。

public static void main(String[] args){
    // 創建File對象
    show(new File("./").getAbsoluteFile());
}

public static void show(File dir) {
    // 獲取子文件和目錄
    File[] files = dir.listFiles();
    // 迴圈列印
    for (File file : files) {
        //判斷是文件,直接輸出
        if (file.isFile()) {
            System.out.println(file);
        } else {
            // 是目錄,繼續遍歷,形成遞歸
            show(file);
        }
    }
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 通過ESLint 檢測 JS/TS 代碼、Prettier 格式化代碼、Stylelint 檢測 CSS/SCSS 代碼和配置 EditorConfig 來實現前端代碼規範約束和統一。 ...
  • “我苦心鍛煉了三年,我變禿了,也變強了。” —— 琦玉老師 0x00 大綱 0x01 前言 四個月前,我在《你是來找茬的吧?對自己的博客進行調優》一文中探討了以博客的使用者而不是開發者身份去進行優化,究竟能做到何種程度的問題。當時以 Edge 瀏覽器的開發者工具里的 lighthouse 評分和載入 ...
  • 並不是所有的場景都適合微服務,我理解技術開發者都有一顆追求新技術的心,但是更重要的是業務場景及團隊。 關於微服務 微服務架構,說白了就是一種上層體系的演變。從最早的單體架構,到前後分離,SOA,甚至微服務架構,其實它們都在做一件事,並且都朝著一個方向去發展:那就是分而治之!從簡! 分而治之有什麼好處 ...
  • 該數據結構需要 Redis 5.0.0 + 版本才可用使用 概述 Redis stream 是 Redis 5 引入的一種新的數據結構,它是一個高性能、高可靠性的消息隊列,主要用於非同步消息處理和流式數據處理。在此之前,想要使用 Redis 實現消息隊列,通常可以使用例如:列表,有序集合、發佈與訂閱 ...
  • c/c++感受演算法快樂(3) 開始時間2023-04-16 22:21:10 結束時間2023-04-17 00:09:34 前言:很好,這周就要結束了,大家都回學校了麽,嘻嘻。回顧一下昨天的演算法題,1.4抓交通肇事犯運用枚舉模擬,1.5兔子產子問題運用迭代迴圈,1.6牛頓迭代法求方程根迭代迴圈,1 ...
  • 前言 在上一篇文章中,我們介紹了<<運算符的高級用法,本篇文章,我們將介紹>> 運算符的一些高級用法。 一、人物簡介 第一位閃亮登場,有請今後會一直教我們C語言的老師 —— 自在。 第二位上場的是和我們一起學習的小白程式猿 —— 逍遙。 二、優化除法運算 除法運算需要比位移運算需要更多的計算資源,某 ...
  • 網路分層結構 電腦網路體系大致分為三種,OSI七層模型、TCP/IP四層模型和五層模型。一般面試的時候考察比較多的是五層模型。最全面的Java面試網站 五層模型:應用層、傳輸層、網路層、數據鏈路層、物理層。 應用層:為應用程式提供交互服務。在互聯網中的應用層協議很多,如功能變數名稱系統DNS、HTTP協議 ...
  • 智能指針 智能指針(序) 相關的概念 指針:一個變數在記憶體中包含的是一個地址(指向其它數據) Rust 中最常見的指針就是”引用“ 引用: 使用 & 借用它指向的值 沒有其餘開銷 最常見的指針類型 智能指針 智能指針是這樣一些數據結構: 行為和指針相似 有額外的元數據和功能 引用計數(Referen ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...