我的学习阶段是跟着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方法进行结合搜索,完成对条件筛选的过滤。