File类、递归
java.io.File类是文件和目录路径名的抽象表示,主要用于文件和目录的创建、查找和删除等操作。
递归指当前方法内调用自己的这种现象,一般的循环不建议使用递归,效率低,每一次方法的执行都会开辟一个栈空间,不过在算法里面倒是蛮有用的,递归回溯、排序,是一种以空间换时间的方法。
不是很难,可以自己写构造个file对象,然后尝试尝试它的一些方法,方法的名字都很好理解,不多说直接上代码,演示下常用的方法以及怎么配合递归遍历到指定文件夹下的所有文件。
public class Review1 {
private static final File file = new File("D:\\file\\b");// (window7的分隔符)
public static void main(String[] args){
// getAllFile(file);
// getTxt();
getAllFile2(file);
}
public static void getTxt() {
File[] files = file.listFiles();// 拿到该路径下的所有文件和目录
for (File file2 : files) {
if (file2.getName().endsWith(".txt")) {// 筛选一下
System.out.println(file2.getPath()+" "+file2.length()+"个字节");
}
}
}
// 开始递归,获取所有该路径下的文件(而不是目录)
public static void getAllFile(File file) {
File[] files = file.listFiles();
for (File file2 : files) {
if (file2.isDirectory()) {
getAllFile(file2);
}else if(file2.isFile()){
System.out.println(file2.getName());
}
}
}
// listFiles可以接收一个FileFilter文件过滤器,我们重写唯一的一个accept方法,该
// 方法只有返回为true时,相应的file的路径对象才可以被返回。直接用lambda表达式写下
public static void getAllFile2(File file) {
File[] files = file.listFiles(pathname->pathname.getName().endsWith(".txt"));
for (File file2 : files) {
System.out.println(file2.getName());
}
}
}