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


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

  • 相关阅读:
    随机出题问题
    简读《构建之法》提问
    大二下第一次课后作业
    大道至简第七第八章读后感
    继承与接口动手动脑
    大道至简第六章读后感
    数组里的随机数问题
    大道至简第五章读后感
    输入法的用户界面
    搜索水王
  • 原文地址:https://www.cnblogs.com/Zyz233/p/10768665.html
Copyright © 2020-2023  润新知