遞歸的注意事項
1、函數自身直接或間接調用了自身
2、遞歸必須明確條件,也要注意遞歸次數,否則容易棧溢出
3、一個功能在被重複使用,並且每次使用,參與運算的結果和上次調用有關。
IO流之深度遍歷文件、刪除目錄操作
package DeepSearchFileDemo;
import java.io.File;
public class DeepSearchFile {
public static void main(String[] args) {
File f1 = new File("D:\\Train_Test_Datasets");
File f2 = new File("D:\\worFile\\Train_Test_Datasets");
deepSearchListFile(f1);
deepDeleteListFile(f2);
}
//將指定目錄下的文件以及子目錄中的文件都顯示出來
public static void deepSearchListFile(File f) {
File[] f3 = f.listFiles(); //獲取當前目錄下的所有文件以及文件
for(int i=0;i<f3.length;i++) {
if(f3[i].isDirectory()) {
System.out.println(f3[i]); //先顯示目錄,再顯示目錄中的文件
deepSearchListFile(f3[i]);
}
else
System.out.println(f3[i]);
}
}
//將指定目錄下的文件以及子目錄中的文件都刪除
public static void deepDeleteListFile(File f) {
File[] f4 = f.listFiles();
for(int i=0;i<f4.length;i++) {
if(f4[i].isDirectory()) {
deepDeleteListFile(f4[i]);
}
else
System.out.println(f4[i]+":"+f4[i].delete()); //刪掉目錄中的文件
}
System.out.println(f+":"+f.delete()); //然後刪除目錄
}
}
文件過濾操作
package FileConstructFuncDemo;
import java.io.File;
public class FileFilterTest {
public static void main(String[] args) {
fileNameFilterDemo();
fileFilterDemo();
}
public static void fileFilterDemo() {
/*
* 文件過濾
*/
File f1 = new File("D:\\software");
String[] names = f1.list();
for(String name : names)
System.out.println(name);
File[] fileFilter = f1.listFiles(new FileFilterInterface());
for(int i=0;i<fileFilter.length;i++)
System.out.println(fileFilter[i]);
}
public static void fileNameFilterDemo() {
/*
* 文件名過濾
*/
File f2 = new File("D:\\software");
String[] names = f2.list(new fileNameFilterInterface(".exe"));
for(String name : names)
System.out.println(name); //打印當前目錄下文件名
File[] f4 = f2.listFiles(new fileNameFilterInterface(".exe"));
for(int i=0;i<f4.length;i++)
System.out.println(f4[i]); //帶有絕對路徑下的文件名
}
}
按文件(後綴名)名過濾
package FileConstructFuncDemo;
import java.io.File;
import java.io.FilenameFilter;
public class fileNameFilterInterface implements FilenameFilter {
private String str; //根據情況,來寫過濾條件
fileNameFilterInterface(String str){
this.str = str;
}
@Override
public boolean accept(File dir, String name) {
return name.endsWith(str);
}
}
根據文件的特點過濾
package FileConstructFuncDemo;
import java.io.File;
import java.io.FileFilter;
public class FileFilterInterface implements FileFilter {
/*
* 自定義文件過濾器
*/
@Override
public boolean accept(File pathname) {
return pathname.length()<1024*1024*50; //將小於50MB的文件顯示出來
}
}