可是,如果我们遍历的文件夹中还包含有文件夹,这个怎么办,那么不着急,我们还有这样一种方法,listFiles() ,可以返回一个抽象路径名数组,这些路径名表示此抽象路径名表示的目录中的文件,返回File对象之后,再进行遍历输出不就好了,多么简单的事情,就像是这样:
File file = new File(“e://mobile”);//输出路径下所有文件和文件夹。
使用递归代码遍历文件夹的文件夹和文件,完整代码参考如下:
运行结果:
- 总结:
基本上所有的循环,都可以用递归来实现,递归降低了代码量,麻烦的是需要增强理解。
一个递归方法每次都是用不同的参数值反复调用自己,当某种参数值使得递归的方法返回,而不再调用自身,这种情况称为边界值,也叫基值。当递归方法返回时,递归过程通过逐渐完成各层方法实例的未执行部分,而从最内层返回到最外层的原始调用处。
阶乘、汉诺塔、归并排序等都可以用递归来实现,但是要注意任何可以用递归完成的算法用栈都能实现。当我们发现递归的方法效率比较低时,可以考虑用循环或者栈来代替它。
第六讲.栈
1、栈的基本概念栈(英语:stack),栈作为一种数据结构,是一种只能在一端进行插入和删除操作的特殊线性表。
这里以羽毛球筒为例,羽毛球筒就是一个栈,刚开始羽毛球筒是空的,也就是空栈,然后我们一个一个放入羽毛球筒,也就是一个一个push进栈,当我们需要使用羽毛球的时候,从筒里面拿,也就是pop出栈,但是第一个拿到的羽毛球是我们最后放进去的。列车入货栈案例