File类遍历(目录功能)、递归
File类遍历(目录功能)
list:返回一个String数组,表示该File目录中的所有子文件或目录
LiistFiles:返回一个File数组,表示该iFile目录中的子文件或者目录
注意:
list方法和listFiles方法遍历的是构造方法中给出的目录
如果构造方法中给出的目录的路径不存在,会抛空指针异常
如果构造方法方法中给出的路径是一个目录,也会抛出空指针异常
案例:
/**
* list:返回一个String数组,表示该File目录中的所有子文件或目录
*
* LiistFiles:返回一个File数组,表示该iFile目录中的子文件或者目录
*
* 注意:
* list方法和listFiles方法遍历的是构造方法中给出的目录
* 如果构造方法中给出的目录的路径不存在,会抛空指针异常
* 如果构造方法方法中给出的路径是一个目录,也会抛出空指针异常
*
*/
private static void show04() {
File file = new File("F://aa.txt");
String[] list = file.list();
for (int i = 0; i < list.length; i++) {
System.out.println(list[i]);
}
File[] files = file.listFiles();
for (File file1 : files) {
System.out.println(file1);
}
}
递归
递归:指在当前方法调用自己的这种现象
递归的分类:
递归分为两种,直接递归和间接递归
直接递归称为方法调用自己
间接递归可以A方法调用B方法,B方法调用C方法,C方法调用A方法
注意事项:
递归一定要又条件限定,保证递归能够停止下来,否者会发生栈内存溢出
在递归中虽然有限定条件,但是递归次数不能太多,否则也会方式栈内存溢出
构造方法禁止递归
我们先来看一个:
public class Digui {
public static void main(String[] args) {
a();
}
// 栈内存溢出
// a方法Exception in thread "main" java.lang.StackOverflowError
private static void a() {
System.out.println("a方法");
a();
}
}
看运行结果
栈会溢出
我们看一为啥会溢出:
图解:
public class Digui {
/**
* 递归一定要又条件限定,保证递归能够停止下来,否者会发生栈内存溢出
* 在递归中虽然有限定条件,但是递归次数不能太多,否则也会方式栈内存溢出
* 构造方法禁止递归
* @param args
*/
public static void main(String[] args) {
b(1);
}
//在递归中虽然有限定条件,但是递归次数不能太多,否则也会方式栈内存溢出
private static void b(int i) {
System.out.println(i);
if (i == 20000) {
return;
}
b(++i);
}
}
次数不能多;
构造方法禁止递归:
直接就会编译报错