复习JavaFile类_递归_综合案例
復(fù)習(xí)File類_遞歸
主要內(nèi)容
- File類
- 遞歸
第一章 File類
1.1 概述
java.io.File 類是文件和目錄路徑名的抽象表示,主要用于文件和目錄的創(chuàng)建、查找和刪除等操作, 這里需要注意一點(diǎn)File不能用于對(duì)文件內(nèi)容進(jìn)行操作, 對(duì)文件內(nèi)容進(jìn)行操作需要使用FileInputStream與FileOutputStream。
1.2 構(gòu)造方法
注: 構(gòu)造File對(duì)象的時(shí)候要注意傳入的參數(shù)是相對(duì)路徑(你要找的文件相對(duì)于當(dāng)前java源文件的位置)還是絕對(duì)路徑(文件的完整路徑, 從磁盤或者根目錄開始), 當(dāng)報(bào)錯(cuò): 文件不能找到, 一定要先看是不是把絕對(duì)路徑寫成相對(duì)路徑.
-
public File(String pathname) :通過將給定的路徑名字符串轉(zhuǎn)換為抽象路徑名來創(chuàng)建新的 File實(shí)例。
-
public File(String parent, String child) :從父路徑名字符串和子路徑名字符串創(chuàng)建新的 File實(shí)例。
-
public File(File parent, String child) :從父抽象路徑名和子路徑名字符串創(chuàng)建新的 File實(shí)例。
-
構(gòu)造舉例,代碼如下:
小貼士:
1.3 常用方法
獲取功能的方法
-
public String getAbsolutePath() :返回此File的絕對(duì)路徑名字符串。
-
public String getPath() :將此File轉(zhuǎn)換為路徑名字符串。
-
public String getName() :返回由此File表示的文件或目錄的名稱。
-
public long length() :返回由此File表示的文件的長(zhǎng)度。
方法演示,代碼如下:
API中說明:length(),表示文件的長(zhǎng)度。但是File對(duì)象表示目錄,則返回值未指定。
絕對(duì)路徑和相對(duì)路徑
- 絕對(duì)路徑:從盤符開始的路徑,這是一個(gè)完整的路徑。
- 相對(duì)路徑:相對(duì)于項(xiàng)目目錄的路徑,這是一個(gè)便捷的路徑,開發(fā)中經(jīng)常使用。
判斷功能的方法
- public boolean exists() :此File表示的文件或目錄是否實(shí)際存在。
- public boolean isDirectory() :此File表示的是否為目錄。
- public boolean isFile() :此File表示的是否為文件。
方法演示,代碼如下:
public class FileIs {public static void main(String[] args) {File f = new File("d:\\aaa\\bbb.java");File f2 = new File("d:\\aaa");// 判斷是否存在System.out.println("d:\\aaa\\bbb.java 是否存在:"+f.exists());System.out.println("d:\\aaa 是否存在:"+f2.exists());// 判斷是文件還是目錄System.out.println("d:\\aaa 文件?:"+f2.isFile());System.out.println("d:\\aaa 目錄?:"+f2.isDirectory());} } 輸出結(jié)果: d:\aaa\bbb.java 是否存在:true d:\aaa 是否存在:true d:\aaa 文件?:false d:\aaa 目錄?:true創(chuàng)建刪除功能的方法
- public boolean createNewFile() :當(dāng)且僅當(dāng)具有該名稱的文件尚不存在時(shí),創(chuàng)建一個(gè)新的空文件。
- public boolean delete() :刪除由此File表示的文件或目錄。
- public boolean mkdir() :創(chuàng)建由此File表示的目錄。
- public boolean mkdirs() :創(chuàng)建由此File表示的目錄,包括任何必需但不存在的父目錄。
方法演示,代碼如下:
public class FileCreateDelete {public static void main(String[] args) throws IOException {// 文件的創(chuàng)建File f = new File("aaa.txt");System.out.println("是否存在:"+f.exists()); // falseSystem.out.println("是否創(chuàng)建:"+f.createNewFile()); // trueSystem.out.println("是否存在:"+f.exists()); // true// 目錄的創(chuàng)建File f2= new File("newDir"); System.out.println("是否存在:"+f2.exists());// falseSystem.out.println("是否創(chuàng)建:"+f2.mkdir()); // trueSystem.out.println("是否存在:"+f2.exists());// true// 創(chuàng)建多級(jí)目錄File f3= new File("newDira\\newDirb");System.out.println(f3.mkdir());// falseFile f4= new File("newDira\\newDirb");System.out.println(f4.mkdirs());// true// 文件的刪除System.out.println(f.delete());// true// 目錄的刪除System.out.println(f2.delete());// trueSystem.out.println(f4.delete());// false} }API中說明:delete方法,如果此File表示目錄,則目錄必須為空才能刪除。
1.4 目錄的遍歷
-
public String[] list() :返回一個(gè)String數(shù)組,表示該File目錄中的所有子文件或目錄。
-
public File[] listFiles() :返回一個(gè)File數(shù)組,表示該File目錄中的所有的子文件或目錄。
小貼士:
調(diào)用listFiles方法的File對(duì)象,表示的必須是實(shí)際存在的目錄,否則返回null,無法進(jìn)行遍歷。
第二章 遞歸
2.1 概述
-
遞歸:指在當(dāng)前方法內(nèi)調(diào)用自己的這種現(xiàn)象。
-
遞歸的分類:
- 遞歸分為兩種,直接遞歸和間接遞歸。
- 直接遞歸稱為方法自身調(diào)用自己。
- 間接遞歸可以A方法調(diào)用B方法,B方法調(diào)用C方法,C方法調(diào)用A方法。
-
注意事項(xiàng):
- 遞歸一定要有條件限定,保證遞歸能夠停止下來,否則會(huì)發(fā)生棧內(nèi)存溢出。
- 在遞歸中雖然有限定條件,但是遞歸次數(shù)不能太多。否則也會(huì)發(fā)生棧內(nèi)存溢出。
- 構(gòu)造方法,禁止遞歸
對(duì)遞歸語句過程存在問題的該出傳送門: 傳送門
2.2 遞歸累加求和
計(jì)算1 ~ n的和
分析:num的累和 = num + (num-1)的累和,所以可以把累和的操作定義成一個(gè)方法,遞歸調(diào)用。
實(shí)現(xiàn)代碼:
public class DiGuiDemo {public static void main(String[] args) {//計(jì)算1~num的和,使用遞歸完成int num = 5;// 調(diào)用求和的方法int sum = getSum(num);// 輸出結(jié)果System.out.println(sum);}/*通過遞歸算法實(shí)現(xiàn).參數(shù)列表:int 返回值類型: int */public static int getSum(int num) {/* num為1時(shí),方法返回1,相當(dāng)于是方法的出口,num總有是1的情況*/if(num == 1){return 1;}/*num不為1時(shí),方法返回 num +(num-1)的累和遞歸調(diào)用getSum方法*/return num + getSum(num-1);} }小貼士:遞歸一定要有條件限定,保證遞歸能夠停止下來,次數(shù)不要太多,否則會(huì)發(fā)生棧內(nèi)存溢出。
2.3 遞歸求階乘
- 階乘:所有小于及等于該數(shù)的正整數(shù)的積。
分析:這與累和類似,只不過換成了乘法運(yùn)算,學(xué)員可以自己練習(xí),需要注意階乘值符合int類型的范圍。
推理得出:n! = n * (n-1)!代碼實(shí)現(xiàn):
public class DiGuiDemo {//計(jì)算n的階乘,使用遞歸完成public static void main(String[] args) {int n = 3;// 調(diào)用求階乘的方法int value = getValue(n);// 輸出結(jié)果System.out.println("階乘為:"+ value);}/*通過遞歸算法實(shí)現(xiàn).參數(shù)列表:int 返回值類型: int */public static int getValue(int n) {// 1的階乘為1if (n == 1) {return 1;}/*n不為1時(shí),方法返回 n! = n*(n-1)!遞歸調(diào)用getValue方法*/return n * getValue(n - 1);} }2.4 遞歸打印多級(jí)目錄
分析:多級(jí)目錄的打印,就是當(dāng)目錄的嵌套。遍歷之前,無從知道到底有多少級(jí)目錄,所以我們還是要使用遞歸實(shí)現(xiàn)。
代碼實(shí)現(xiàn):
public class DiGuiDemo2 {public static void main(String[] args) {// 創(chuàng)建File對(duì)象File dir = new File("D:\\aaa");// 調(diào)用打印目錄方法printDir(dir);}public static void printDir(File dir) {// 獲取子文件和目錄File[] files = dir.listFiles();// 循環(huán)打印/*判斷:當(dāng)是文件時(shí),打印絕對(duì)路徑.當(dāng)是目錄時(shí),繼續(xù)調(diào)用打印目錄的方法,形成遞歸調(diào)用.*/for (File file : files) {// 判斷if (file.isFile()) {// 是文件,輸出文件絕對(duì)路徑System.out.println("文件名:"+ file.getAbsolutePath());} else {// 是目錄,輸出目錄絕對(duì)路徑System.out.println("目錄:"+file.getAbsolutePath());// 繼續(xù)遍歷,調(diào)用printDir,形成遞歸printDir(file);}}} }第三章 綜合案例
3.1 文件搜索
搜索D:\aaa 目錄中的.java 文件。
分析:
代碼實(shí)現(xiàn):
public class DiGuiDemo3 {public static void main(String[] args) {// 創(chuàng)建File對(duì)象File dir = new File("D:\\aaa");// 調(diào)用打印目錄方法printDir(dir);}public static void printDir(File dir) {// 獲取子文件和目錄File[] files = dir.listFiles();// 循環(huán)打印for (File file : files) {if (file.isFile()) {// 是文件,判斷文件名并輸出文件絕對(duì)路徑if (file.getName().endsWith(".java")) {System.out.println("文件名:" + file.getAbsolutePath());}} else {// 是目錄,繼續(xù)遍歷,形成遞歸printDir(file);}}} }3.2 文件過濾器優(yōu)化
java.io.FileFilter是一個(gè)接口,是File的過濾器。 該接口的對(duì)象可以傳遞給File類的listFiles(FileFilter) 作為參數(shù), 接口中只有一個(gè)方法。
boolean accept(File pathname) :測(cè)試pathname是否應(yīng)該包含在當(dāng)前File目錄中,符合則返回true。
分析:
代碼實(shí)現(xiàn):
public class DiGuiDemo4 {public static void main(String[] args) {File dir = new File("D:\\aaa");printDir2(dir);}public static void printDir2(File dir) {// 匿名內(nèi)部類方式,創(chuàng)建過濾器子類對(duì)象File[] files = dir.listFiles(new FileFilter() {//重寫accept, 規(guī)定過濾的準(zhǔn)則//此處操作類似于比較器, 使用Collections.sort(Comparator com)排序的時(shí)候, 我們可以傳入一個(gè)比較器對(duì)象@Overridepublic boolean accept(File pathname) {return pathname.getName().endsWith(".java")||pathname.isDirectory();}});// 循環(huán)打印for (File file : files) {if (file.isFile()) {System.out.println("文件名:" + file.getAbsolutePath());} else {printDir2(file);}}} }3.3 Lambda優(yōu)化
分析:FileFilter是只有一個(gè)方法的接口,因此可以用lambda表達(dá)式簡(jiǎn)寫。
lambda格式:
()->{ }代碼實(shí)現(xiàn):
public static void printDir3(File dir) {// lambda的改寫File[] files = dir.listFiles(f ->{ return f.getName().endsWith(".java") || f.isDirectory(); });// 循環(huán)打印for (File file : files) {if (file.isFile()) {System.out.println("文件名:" + file.getAbsolutePath());} else {printDir3(file);}} }總結(jié)
以上是生活随笔為你收集整理的复习JavaFile类_递归_综合案例的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python坦克大战_Life is s
- 下一篇: 5类主题词汇(4)