一、File類
java.io.File
類是文件和目錄路徑名的抽象表示,主要用於文件和目錄的創建、查找和刪除等操作。
1、構造方法
public File(String pathname)
:通過將給定的路徑名字符串轉換爲抽象路徑名來創建新的 File實例。
public File(String parent, String child)
:從父路徑名字符串和子路徑名字符串創建新的 File實例。
public File(File parent, String child)
:從父抽象路徑名和子路徑名字符串創建新的 File實例。
構造舉例,代碼如下:
// 文件路徑名
String pathname = "D:\\aaa.txt";
File file1 = new File(pathname);
// 文件路徑名
String pathname2 = "D:\\aaa\\bbb.txt";
File file2 = new File(pathname2);
// 通過父路徑和子路徑字符串
String parent = "d:\\aaa";
String child = "bbb.txt";
File file3 = new File(parent, child);
// 通過父級File對象和子路徑字符串
File parentDir = new File("d:\\aaa");
String child = "bbb.txt";
File file4 = new File(parentDir, child);
2、常用方法
1)獲取功能的方法
public String getAbsolutePath()
:返回此File的絕對路徑名字符串。
public String getPath()
:將此File轉換爲路徑名字符串。
public String getName()
:返回由此File表示的文件或目錄的名稱。
public long length()
:返回由此File表示的文件的長度。
2)絕對路徑和相對路徑
絕對路徑:從盤符開始的路徑,這是一個完整的路徑,有\ \表示。 相對路徑:相對於項目目錄的路徑,這是一個便捷的路徑,開發中經常使用。
public class FilePath {
public static void main(String[] args) {
// D盤下的bbb.java文件
File f = new File("D:\\bbb.java");
System.out.println(f.getAbsolutePath());
// 項目下的bbb.java文件
File f2 = new File("bbb.java");
System.out.println(f2.getAbsolutePath());
}
}
輸出結果:
D:\bbb.java
D:\idea_project_test4\bbb.java
3)判斷功能的方法
public boolean exists()
:此File表示的文件或目錄是否實際存在。
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());
}
}
輸出結果:
d:\aaa\bbb.java 是否存在:true
d:\aaa 是否存在:true
d:\aaa 文件?:false
d:\aaa 目錄?:true
4)創建刪除功能的方法
public boolean createNewFile()
:當且僅當具有該名稱的文件尚不存在時,創建一個新的空文件。
public boolean delete()
:刪除由此File表示的文件或目錄。
public boolean mkdir()
:創建由此File表示的目錄。
public boolean mkdirs()
:創建由此File表示的目錄,包括任何必需但不存在的父目錄。
public class FileCreateDelete {
public static void main(String[] args) throws IOException {
// 文件的創建
File f = new File("aaa.txt");
System.out.println("是否存在:"+f.exists()); // false
System.out.println("是否創建:"+f.createNewFile()); // true
System.out.println("是否存在:"+f.exists()); // true
// 目錄的創建
File f2= new File("newDir");
System.out.println("是否存在:"+f2.exists());// false
System.out.println("是否創建:"+f2.mkdir()); // true
System.out.println("是否存在:"+f2.exists());// true
// 創建多級目錄
File f3= new File("newDira\\newDirb");
System.out.println(f3.mkdir());// false
File f4= new File("newDira\\newDirb");
System.out.println(f4.mkdirs());// true
// 文件的刪除
System.out.println(f.delete());// true
// 目錄的刪除
System.out.println(f2.delete());// true
System.out.println(f4.delete());// false
}
}
3、目錄的遍歷
public String[] list()
:返回一個String數組,表示該File目錄中的所有子文件或目錄。
public File[] listFiles()
:返回一個File數組,表示該File目錄中的所有的子文件或目錄。
public class FileFor {
public static void main(String[] args) {
File dir = new File("d:\\java_code");
//獲取當前目錄下的文件以及文件夾的名稱。
String[] names = dir.list();
for(String name : names){
System.out.println(name);
}
//獲取當前目錄下的文件以及文件夾對象,只要拿到了文件對象,那麼就可以獲取更多信息
File[] files = dir.listFiles();
for (File file : files) {
System.out.println(file);
}
}
}
二、遞歸
遞歸:方法自己調用自己
1、 遞歸的分類:遞歸分爲兩種,直接遞歸和間接遞歸。
直接遞歸稱爲方法自身調用自己。間接遞歸可以A方法調用B方法,B方法調用C方法,C方法調用A方法。
2、遞歸注意事項:
1)遞歸一定要有條件限定,保證遞歸能夠停止下來,否則會發生棧內存溢出。
2) 在遞歸中雖然有限定條件,但是遞歸次數不能太多。否則也會發生棧內存溢出。
3)構造方法,禁止遞歸。
3、遞歸的使用前提:當調用方法的時候,方法的主體不變,每次調用方法的參數不同,可以使用遞歸。
4、遞歸打印多級目錄代碼實現:
public class DiGuiDemo2 {
public static void main(String[] args) {
// 創建File對象
File dir = new File("D:\\aaa");
// 調用打印目錄方法
printDir(dir);
}
public static void printDir(File dir) {
// 獲取子文件和目錄
File[] files = dir.listFiles();
// 循環打印
/*
判斷:
當是文件時,打印絕對路徑.
當是目錄時,繼續調用打印目錄的方法,形成遞歸調用.
*/
for (File file : files) {
// 判斷
if (file.isFile()) {
// 是文件,輸出文件絕對路徑
System.out.println("文件名:"+ file.getAbsolutePath());
} else {
// 是目錄,輸出目錄絕對路徑
System.out.println("目錄:"+file.getAbsolutePath());
// 繼續遍歷,調用printDir,形成遞歸
printDir(file);
}
}
}
}
5、使用遞歸進行文件搜索(搜索D:\aaa
目錄中的.java
文件。)
public class DiGuiDemo3 {
public static void main(String[] args) {
// 創建File對象
File dir = new File("D:\\aaa");
// 調用打印目錄方法
printDir(dir);
}
public static void printDir(File dir) {
// 獲取子文件和目錄
File[] files = dir.listFiles();
// 循環打印
for (File file : files) {
if (file.isFile()) {
// 是文件,判斷文件名並輸出文件絕對路徑
if (file.getName().endsWith(".java")) {
System.out.println("文件名:" + file.getAbsolutePath());
}
} else {
// 是目錄,繼續遍歷,形成遞歸
printDir(file);
}
}
}
}
6、文件過濾器優化
java.io.FileFilter是一個接口,是File的過濾器。 該接口的對象可以傳遞給File類的
listFiles(FileFilter)作爲參數, 接口中只有一個方法。
boolean accept(File pathname) ` :測試pathname是否應該包含在當前File目錄中,符合則返回true。
在File類中有兩個和ListFiles重載的方法,方法的參數傳遞的就是過濾器
File[] listFiles(FileFilter filter)
java.io.FileFilter接口:用於抽象路徑名(File對象)的過濾器。
作用:用來過濾文件(File對象)
抽象方法:用來過濾文件的方法
boolean accept(File pathname) 測試指定抽象路徑名是否應該包含在某個路徑名列表中。
參數:
File pathname:使用ListFiles方法遍歷目錄,得到的每一個文件對象
File[] listFiles(FilenameFilter filter)
java.io.FilenameFilter接口:實現此接口的類實例可用於過濾器文件名。
作用:用於過濾文件名稱
抽象方法:用來過濾文件的方法
boolean accept(File dir, String name) 測試指定文件是否應該包含在某一文件列表中。
參數:
File dir:構造方法中傳遞的被遍歷的目錄
String name:使用ListFiles方法遍歷目錄,獲取的每一個文件/文件夾的名稱
注意:
兩個過濾器接口是沒有實現類的,需要我們自己寫實現類,重寫過濾的方法accept,在方法中自己定義過濾的規則
過濾器原理:
代碼實現:
public class DiGuiDemo4 {
public static void main(String[] args) {
File dir = new File("D:\\aaa");
printDir2(dir);
}
public static void printDir2(File dir) {
// 匿名內部類方式,創建過濾器子類對象
File[] files = dir.listFiles(new FileFilter() {
@Override
public boolean accept(File pathname) {
return pathname.getName().endsWith(".java")||pathname.isDirectory();
}
});
// 循環打印
for (File file : files) {
if (file.isFile()) {
System.out.println("文件名:" + file.getAbsolutePath());
} else {
printDir2(file);
}
}
}
}
7、Lambda優化
FileFilter
是隻有一個方法的接口,因此可以用lambda表達式簡寫。
lambda格式:()->{ }
public static void printDir3(File dir) {
// lambda的改寫
File[] files = dir.listFiles(f ->{
return f.getName().endsWith(".java") || f.isDirectory();
});
// 循環打印
for (File file : files) {
if (file.isFile()) {
System.out.println("文件名:" + file.getAbsolutePath());
} else {
printDir3(file);
}
}
}