首页 > 编程语言 > 详细

#Java学习之路——基础阶段二(第六篇)

时间:2019-04-25 15:34:05      阅读:111      评论:0      收藏:0      [点我收藏+]

我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容。

前言:此随笔主要是Java基础中的基础,相信大家对这方面肯定有着自己的理解和认识,具体详解可以参照万能的baidu,有的我就一笔带过,希望在我的学习之路上能够有大牛进行指导,也有更多的小伙伴共勉。

1.File类

File类是文件名和目录路径名的抽象表示,主要适用于文件和目录的创建、查找和删除功能;

构造方法有三种

1.直接通过给定的路径名字符串转换为抽象路径名来创建;

2.是通过父路径和子路径名字符串创建

3.通过父路径的抽象路径和子路径名字符串创建

简单来说第一种方法是直接通过String 类传给File类对象创建,第二种是通过String创建目录和文件组合在一起的,第三只是通过File抽象类创建一个父目录路径,再用String类创建子类文件名进行创建;

常用的方法:

·getAbsoultePath 获取文件的绝对路径

·getPath 将文件路径转换为字符串

·getName 获取文件或者是目录名

·length 获取文件或目录长度

绝对路径和相对路径的区别:

绝对路径是以根目录为开始的路径;

相对路径是以项目分目录开始的路径。

判断方法:

·exists 是否存在文件或者文件夹

·isDirectory 是否为目录

·isFile 是否是文件

创建功能方法:

·creatNewFile 创建新文件夹

·delete 删除文件夹(目录文件夹必须为空,否则不能删除)

·mkdir 创建此File为目录

·mkdirs 创建多级目录

目录的遍历:

·list方法 先将文件和文件目录存入到数组中,用for循环来进行遍历,这里是当前目录下的遍历,遍历出当前目录下的文件和文件夹名称

·listFiles方法 先将文件和文件目录存入到数组中,用for循环来进行遍历,这里遍历出的是文件夹和文件对象,获取对象后就可以获取更多的信息加以遍历(listFile遍历的文件夹必须是真实存在的否则返回的值是null值)

2.递归

递归是指当前方法内调用自己的现象,分为直接递归和间接递归

注意:递归一定要有一定的次数和条件限定来控制能够停下来,否则会持续递归和循环中的死循环一样是非常严重的错误,造成栈内存溢出。

构造方法不能进行递归,构造方法是用来构造对象的,如果递归就会一直构造对象。

递归对于上文写到的File类就可以很好的运用到,遍历出所有文件。

用listFile方法获取所有的目录文件和文件对象,存入到数组中,然后对数组进行for循环遍历判断isFile,如果返回ture则遍历出文件名,如果是 false 则将获取的相对路径 再次调用遍历方法再一次获取,这样就可以层层递归获取所有文件名称。

对于文件夹目录下的文件搜索,可以使用过滤器进行条件筛选后的过滤,像以什么文件格式结尾可以用endwith方法进行判断对遍历出的文件进行判断符合则输出,不符合则继续进行遍历操作。

关于过滤器这里要讲的是FileFilter接口中的accpet方法,返回值是boolean类型,可以通过匿名内部类来实现使用accpet方法,减少实现接口的实现类操作,这里要用到的方法还有getPath方法获取文件的绝对路径,和geName方法,还有判断是否是isDIrectory方法进行结合搜索,完成对条件筛选的过滤。

#Java学习之路——基础阶段二(第六篇)

原文:https://www.cnblogs.com/Zyz233/p/10768665.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!