前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >File类、递归

File类、递归

作者头像
全栈程序员站长
发布2022-06-29 15:05:58
3650
发布2022-06-29 15:05:58
举报
文章被收录于专栏:全栈程序员必看

File类 File类的静态成员变量

代码语言:javascript
复制
package com.itheima.demo01.File;

import java.io.File;

/* java.io.File类 文件和目录路径名的抽象表示形式。 java把电脑中的文件和文件夹(目录)封装为了一个File类,我们可以使用File类对文件和文件夹进行操作 我们可以使用File类的方法 创建一个文件/文件夹 删除文件/文件夹 获取文件/文件夹 判断文件/文件夹是否存在 对文件夹进行遍历 获取文件的大小 File类是一个与系统无关的类,任何的操作系统都可以使用这个类中的方法 重点:记住这三个单词 file:文件 directory:文件夹/目录 path:路径 */
public class Demo01File {
   
    public static void main(String[] args) {
   
// static String pathSeparator 与系统有关的路径分隔符,为了方便,它被表示为一个字符串。
// static char pathSeparatorChar 与系统有关的路径分隔符。

// static String separator 与系统有关的默认名称分隔符,为了方便,它被表示为一个字符串。
// static char separatorChar 与系统有关的默认名称分隔符。
        /* 操作路径:路径不能写死了 C:\develop\a\a.txt windows C:/develop/a/a.txt linux "C:"+File.separator+"develop"+File.separator+"a"+File.separator+"a.txt" */

        String pathSeparator = File.pathSeparator;
        System.out.println(pathSeparator);//路径分隔符 Windows:分号; linux:冒号:

        String separator = File.separator;
        System.out.println(separator);//文件名称分隔符 Windows:反斜杠\ linux:正斜杠/
    }
}

绝对路径和相对路径

代码语言:javascript
复制
package com.itheima.demo01.File;
/* 路径: 绝对路径:是一个完整的路径 以盘符开始的路径 相对路径:是一个简化的路径 相对指的是相对于当前项目的根目录 如果使用当前项目的根目录,路径可以简化书写 注意: 1.路径是不区分大小写的 2.路径中的文件名称分隔符windows使用反斜杠,反斜杠是转义字符,两个反斜杠代表一个普通反斜杠 */
public class Demo02File {
   
}

File类的构造方法

代码语言:javascript
复制
package com.itheima.demo01.File;

import java.io.File;

/* 路径: 绝对路径:是一个完整的路径 以盘符开始的路径 相对路径:是一个简化的路径 相对指的是相对于当前项目的根目录 如果使用当前项目的根目录,路径可以简化书写 注意: 1.路径是不区分大小写的 2.路径中的文件名称分隔符windows使用反斜杠,反斜杠是转义字符,两个反斜杠代表一个普通反斜杠 */
public class Demo02File {
   
    public static void main(String[] args) {
   
        /* File类的构造方法 */
        //show01();
       // show02("c:\\","a.txt");
        show03();
    }


    /* File(File parent, String child) 根据 parent 抽象路径名和 child 路径名字符串创建一个新 File 实例 参数:把路径分成了两部分 File parent:父路径 String child:子路径 好处: 父路径和子路径,可以单独书写,使用起来非常灵活;父路径和子路径都可以变化 父路径是File类型,可以使用File的方法对路径进行一些操作,再使用路径创建对象 */
    private static void show03() {
   
        File parent = new File("c:\\");
        File file = new File(parent,"hello.java");
        System.out.println(file);//c:\hello.java
    }


    /* File(String parent, String child) 根据 parent 路径名字符串和 child 路径名字符串创建一个新 File 实例。 参数:把路径分成了两部分 String parent:父路径 String child:子路径 好处: 父路径和子路径,可以单独书写,使用起来非常灵活;父路径和子路径都可以变化 */
    private static void show02(String parent, String child) {
   
        File file = new File(parent, child);
        System.out.println(file);// c:\a.txt
    }

    /* File(String pathname) 通过将给定路径名字字符串转换为抽象路径名来创建一个新File实例。 参数: String pathname:字符串的路径名称 路径可以是以文件结尾,也可以是以文件夹结尾 路径可以是相对路径,也可以是绝对路径 路径可以是存在的,也可以是不存在的 创建File对象,只是把字符串路径封装为File对象,不考虑路径的真假情况 */
    private static void show01() {
   
        File f1 = new File("D:\\BaiduNetdiskDownload\\u3d\\a.txt");
        System.out.println(f1);//重写了Object类的toString方法


        File f2 = new File("D:\\BaiduNetdiskDownload\\u3d");
        System.out.println(f2);

        File f3 = new File("b.txt");
        System.out.println(f3);
    }
}

File类获取功能的方法

代码语言:javascript
复制
package com.itheima.demo01.File;

import java.io.File;

/* File类获取功能的方法: public String getAbsolutePath() :返回此File的绝对路径名字符串。 public String getPath() :将此File转换为路径名字符串。 public String getName() :返回由此File表示的文件或目录的名称。 public long length() :返回由此File表示的文件的长度。 */
public class Demo03File{
   
    public static void main(String[] args) {
   
        show04();
    }

    /* public long length() :返回由此File表示的文件的长度。 获取的是构造方法指向的文件的大小,以字节为单位 注意: 文件夹是没有大小概念的,不能获取文件夹的大小 如果构造方法中给出的路径不存在,那么length方法返回0 */
    private static void show04() {
   
        File f1 = new File("D:\\BaiduNetdiskDownload\\u3d\\Chapter1\\Chapter1.unitypackage");
        long l1 = f1.length();
        System.out.println(l1);//3722011字节

        File f2 = new File("D:\\BaiduNetdiskDownload\\u3d\\Chapter1\\Chapter2.unitypackage");
        long l2 = f2.length();
        System.out.println(l2);//0

        File f3 = new File("D:\\BaiduNetdiskDownload\\u3d\\Chapter1");
        long l3 = f3.length();
        System.out.println(l3);//0 文件夹没有大小概念
    }

    /* public String getName() :返回由此File表示的文件或目录的名称。 获取的就是构造方法传递路径的结尾部分(文件/文件夹) */
    private static void show03() {
   
        File f1 = new File("D:\\IdeaProjects\\1_2\\a.txt");
        String name1 = f1.getName();
        System.out.println(name1);

        File f2 = new File("D:\\IdeaProjects\\1_2");
        String name2 = f2.getName();
        System.out.println(name2);
    }


    /* public String getPath() :将此File转换为路径名字符串。 获取的构造方法中传递的路径 toString 方法调用的就是getPath方法 源码: public String toString(){ return getPath(); } */
    private static void show02() {
   
        File f1 = new File("D:\\IdeaProjects\\1_2\\a.txt");
        File f2 = new File("a.txt");
        String path1 = f1.getPath();
        System.out.println(path1);
        String path2 = f2.getPath();
        System.out.println(path2);

        System.out.println(f1);
        System.out.println(f1.toString());
    }

    /* public String getAbsolutePath() :返回此File的绝对路径名字符串。 获取的构造方法中传递的路径 无论路径是绝对的还是相对的,getAbsolutePath方法返回的都是绝对路径 */
    private static void show01() {
   
        File f1 = new File("D:\\IdeaProjects\\1_2\\a.txt");
        String absolutePath1 = f1.getAbsolutePath();
        System.out.println(absolutePath1);

        File f2 = new File("a.txt");
        String absolutePath2 = f2.getAbsolutePath();
        System.out.println(absolutePath2);
    }
}

File类判断功能的方法

代码语言:javascript
复制
package com.itheima.demo01.File;

import java.io.File;

/* File判断功能的方法: public boolean exists() :此File表示的文件或目录是否实际存在。 public boolean isDirectory() :此File表示的是否为目录。 public boolean isFile() :此File表示的是否为文件。 */
public class Demo04File {
   
    public static void main(String[] args) {
   
        show02();
    }

    /* public boolean isDirectory() :此File表示的是否为目录。 用于判断构造方法中给定的路径是否以文件夹结尾 是:true 否:false public boolean isFile() :此File表示的是否为文件。 用于判断构造方法中给定的路径是否以文件结尾 是:true 否:false 注意: 电脑的硬盘中只有文件/文件夹,两个方法是互斥 这两个方法使用前提,路径必须是存在的,否则都返回false */
    private static void show02() {
   
        File f1 = new File("D:\\IdeaProjects\\1_2");
        System.out.println(f1.isDirectory());//true

        File f2 = new File("D:\\IdeaProjects\\1_2\\1_2.iml");
        System.out.println(f2.isDirectory());//false

        File f3 = new File("D:\\IdeaProjects\\1_2\\1_2.iml");
        System.out.println(f3.isFile());//true

        File f4 = new File("D:\\IdeaProjects\\1_3");
        System.out.println(f4.isDirectory());//false
        
        File f5 = new File("D:\\IdeaProjects\\1_3\\1_2.iml");
        System.out.println(f5.isFile());//false
    }

    /* public boolean exists() :此File表示的文件或目录是否实际存在。 用于判断构造方法中的路径是否存在 存在:true 不存在:false */
    private static void show01() {
   
        File f1 = new File("D:\\IdeaProjects\\1_2");
        System.out.println(f1.exists());//true

        File f2 = new File("D:\\IdeaProjec\\1_2");
        System.out.println(f2.exists());//false

        File f3 = new File("1_2.iml");//相对路径
        System.out.println(f3.exists());//true

        File f4 = new File("1_3.iml");//相对路径
        System.out.println(f4.exists());//false
    }
}

File类创建删除功能的方法

代码语言:javascript
复制
package com.itheima.demo01.File;

import java.io.File;
import java.io.IOException;

/* File类创建删除功能的方法 public boolean createNewFile() :当且仅当具有该名称的文件尚不存在时,创建一个新的空文件。 public boolean delete() :删除由此File表示的文件或目录。 public boolean mkdir() :创建由此File表示的目录。 public boolean mkdirs() :创建由此File表示的目录,包括任何必需但不存在的父目录。 */
public class Demo05File {
   
    public static void main(String[] args) throws IOException {
   
        show01();
    }

    /* public boolean createNewFile() :当且仅当具有该名称的文件尚不存在时,创建一个新的空文件。 创建文件的路径和名称再构造方法中给出(构造方法的参数) 返回值:布尔值 true:文件不存在,创建文件,返回true false:文件存在,不会创建,返回false 注意: 1.此方法只能创建文件,不能创建文件夹 2.创建文件的路径必须存在,否则会抛出异常 public boolean createNewFile() throws IOException createNewFile声明抛出了IOException,我们调用这个方法,就必须处理这个异常,要么throws,要么trycatch */
    private static void show01() throws IOException {
   
        File f1 = new File("D:\\IdeaProjects\\1_2\\1.txt");
        boolean b1 = f1.createNewFile();
        System.out.println(b1);

        File f2 = new File("2.txt");
        boolean b2 = f2.createNewFile();
        System.out.println(b2);

        File f3 = new File("新建文件夹");//不要被名称迷惑,要看类型
        boolean b3 = f3.createNewFile();
        System.out.println(b3);
    }
}

File类遍历(文件夹)目录功能

代码语言:javascript
复制
package com.itheima.demo01.File;

import java.io.File;

/* File类遍历文件(文件夹)目录功能: public String[] list() :返回一个String数组,表示该File目录中的所有子文件或目录。 public File[] listFiles() :返回一个File数组,表示该File目录中的所有的子文件或目录。 注意: List方法和ListFile方法遍历的是构造方法中给出的目录 如果构造方法中给出的目录的路径不存在,会抛出空指针异常 如果构造方法中给出的路径不是一个目录,也会抛出空指针异常 */
public class Demo06File {
   
    public static void main(String[] args) {
   
        show02();
    }
    /* public File[] listFiles() :返回一个File数组,表示该File目录中的所有的子文件或目录。 遍历构造方法中给出的目录,会获取目录中所有的文件/文件夹,把获取到的多个名称存储到一个String类型的数组中 */
    private static void show02() {
   
        File f1 = new File("D:\\IdeaProjects");
        File[] files = f1.listFiles();
        for (File file : files) {
   
            System.out.println(file);
        }
    }

    /* public String[] list() :返回一个String数组,表示该File目录中的所有子文件或目录。 遍历构造方法中给出的目录,会获取目录中所有文件/文件夹的名称,把获取到的多个名称存储到一个String类型的数组中 */
    private static void show01() {
   
        //File f1 = new File("D:\\IdeaProjects");
        //File f1 = new File("D:\\IdeaProjects\\1_2\\1.txt");//NullPointerException
        File f1 = new File("D:\\IdeaProjec");//NullPointerException
        String[] arr = f1.list();
        for (String filename : arr) {
   
            System.out.println(filename);
        }
    }
}

递归概念&分类&注意事项

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
package com.itheima.demo02.Recurison;
/* 递归:指在当前方法内调用自己的这种现象。 -递归的分类: -递归分为两种,直接递归和间接递归。 -直接递归称为方法自身调用自己。 -间接递归可以A方法调用B方法,B方法调用C方法,C方法调用A方法。 -注意事项: -递归一定要有条件限定,保证递归能够停止下来,否则会发生栈内存溢出。 -在递归中虽然有限定条件,但是递归次数不能太多。否则也会发生栈内存溢出。 -构造方法,禁止递归 递归的使用前提: 当调用方法的时候,方法的主体不变,每次调用方法的参数不同,可以使用递归 */
public class Demo01Recurison {
   
    public static void main(String[] args) {
   
        //a();
        b(1);
    }
    
    /* 构造方法,禁止递归 编译报错:构造方法是创建对象使用的,一直递归会导致内存中有无数多个对象,直接编译报错 */
    public Demo01Recurison(){
   
        //Demo01Recurison();
    }

    /* 在递归中虽然有限定条件,但是递归次数不能太多。否则也会发生栈内存溢出。 Exception in thread "main" java.lang.StackOverflowError */
    private static void b(int i) {
   
        System.out.println(i);
        if(i==20000){
   
            return;//结束方法
        }
        b(++i);
    }

    /* 递归一定要有条件限定,保证递归能够停止下来,否则会发生栈内存溢出 Exception in thread "main" java.lang.StackOverflowError */
    private static void a() {
   
        System.out.println("a方法!");
        a();
    }
}

使用递归计算1-n之间的和

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
package com.itheima.demo02.Recurison;
/* 练习: 使用递归计算1-n之间的和 */
public class Demo02Recurison {
   
    public static void main(String[] args) {
   
        int s = sum(3);
        System.out.println(s);
    }

    /* 定义一个方法,使用递归计算1-n之间的和 1+2+3+...+n n+(n-1)+(n-2)+...+1 已知: 最大值:n 最小值:1 使用递归必须明确: 1.递归的结束条件 获取到1的时候结束 2.递归的目的 获取下一个被加的数字(n-1) */
    public static int sum(int n){
   
        //获取到1的时候结束
        if(n==1){
   
            return 1;
        }
        //获取下一个被加的数字(n-1)
        return n+sum(n-1);
    }
}

练习_使用递归计算阶乘

代码语言:javascript
复制
package com.itheima.demo02.Recurison;
/* 用递归计算阶乘 recursion */
public class Demo03Recurison {
   
    public static void main(String[] args) {
   
        int i = jieCheng(5);
        System.out.println(i);
    }

    /* 定义方法用递归计算阶乘 递归结束的条件 获取到1的时候结束 递归的目的 获取下一个被乘的数字(n-1) */
    private static int jieCheng(int n) {
   
        if(n==1){
   
            return 1;
        }

        return n*jieCheng(n-1);
    }
}

练习 递归打印多级目录

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
package com.itheima.demo02.Recurison;

import java.io.File;
import java.io.IOException;

public class Demo04Recurison {
   
    public static void main(String[] args) throws IOException {
   

     creat();
     File file = new File("C:\\abc");
     getAllFile(file);
   }

   //遍历目录
    public static void getAllFile(File dir){
   
        //System.out.println(dir);//打印被遍历的目录名称
        File[] files = dir.listFiles();
        for (File f : files) {
   
            //对遍历得到的File对象f进行判断,判断是否是文件夹
            if(f.isDirectory()){
   
                getAllFile(f);
            }else{
   
                //f是一个文件直接打印即可
                /* 文件搜索: 只要.java结尾的文件 */
                //String name = f.getName();//只有文件名
                //String path = f.getPath();//文件路径
                String s = f.toString();
                if(s.endsWith(".java")){
   
                    System.out.println(s);
                }

            }
        }
    }


   //创建文件
    public static void creat() throws IOException {
   
        new File("C:\\abc").mkdir();

        new File("C:\\abc\\a").mkdir();

        new File("C:\\abc\\b").mkdir();

        new File("C:\\abc\\abc.txt").createNewFile();
        new File("C:\\abc\\abc.java").createNewFile();
        new File("C:\\abc\\a\\a.jpg").createNewFile();
        new File("C:\\abc\\a\\a.java").createNewFile();
        new File("C:\\abc\\b\\b.java").createNewFile();
        new File("C:\\abc\\b\\b.txt").createNewFile();
    }


}

综合案例_文件搜索 见上面

FileFilter过滤器的原理和使用

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
package com.itheima.demo03.Filter;

import java.io.File;
import java.io.FileFilter;
import java.io.IOException;

/* 需求: 遍历C:\abc文件夹,及abc文件夹的子文件夹 只要.java结尾的文件 C:\abc C:\abc\a C:\abc\a\a.java C:\abc\a\a.jpg C:\abc\abc.java C:\abc\abc.txt C:\abc\b C:\abc\b\b.java C:\abc\b\b.txt 我们可以使用过滤器来实现 在File类中有两个和ListFiles重载的方法,方法的参数传递的就是过滤器 1.File[] listFiles(FileFilter filter) java.io.FileFilter接口:用于抽象路径名(File对象)的过滤器 作用:用于过滤文件(File对象) 抽象方法:用来过滤文件的方法 boolean accept(File pathname) 测试指定抽象路径名是否应该包含在某个路径名列表中。 参数: File pathname:使用ListFiles方法遍历目录,得到的每一个文件对象 2.File[] listFiles(FilenameFilter filter) java.io.FilenameFilter接口:实现此接口的类实例可用于过滤器文件名 作用:用于过滤文件名称 抽象方法:用来过滤文件的方法 boolean accept(File dir, String name) 测试指定文件是否应该包含在某一文件列表中。 参数: File dir:构造方法中传递的被遍历的目录 String name:使用ListFiles方法遍历目录,获取的每一个文件/文件夹的名称 注意: 两个过滤器接口没有实现类,需要我们自己写实现类,重写过滤的方法accept,在方法中自己定义过滤的规则 */
public class Demo01Filter {
   
    public static void main(String[] args) throws IOException {
   
        File file = new File("C:\\abc");
        getAllFile(file);
    }

    //遍历目录
    public static void getAllFile(File dir){
   
        File[] files = dir.listFiles(new FileFilterImpl());//传递过滤器对象
        for (File f : files) {
   
            //对遍历得到的File对象f进行判断,判断是否是文件夹
            if(f.isDirectory()){
   
                getAllFile(f);
            }else{
   
                System.out.println(f);
            }
        }
    }
}
代码语言:javascript
复制
package com.itheima.demo03.Filter;

import java.io.File;
import java.io.FileFilter;

/* 创建过滤器FileFilter的实现类,重写过滤方法accept,定义过滤规则 */
public class FileFilterImpl implements FileFilter{
   
    @Override
    public boolean accept(File pathname) {
   
        /* 过滤规则: 在accept方法中,判断File对象是否以.java结尾 是就返回true 不是就返回false */
        //如果pathname是一个文件夹,返回true,继续遍历这个文件夹
        if(pathname.isDirectory()){
   
            return true;
        }
          
        return(pathname.getName().toLowerCase().endsWith(".java"));

    }
}

FileNameFilter过滤器的使用和Lambda优化程序

代码语言:javascript
复制
package com.itheima.demo03.Filter;

import java.io.File;
import java.io.FileFilter;
import java.io.FilenameFilter;
import java.io.IOException;

/* 需求: 遍历C:\abc文件夹,及abc文件夹的子文件夹 只要.java结尾的文件 C:\abc C:\abc\a C:\abc\a\a.java C:\abc\a\a.jpg C:\abc\abc.java C:\abc\abc.txt C:\abc\b C:\abc\b\b.java C:\abc\b\b.txt 我们可以使用过滤器来实现 在File类中有两个和ListFiles重载的方法,方法的参数传递的就是过滤器 1.File[] listFiles(FileFilter filter) java.io.FileFilter接口:用于抽象路径名(File对象)的过滤器 作用:用于过滤文件(File对象) 抽象方法:用来过滤文件的方法 boolean accept(File pathname) 测试指定抽象路径名是否应该包含在某个路径名列表中。 参数: File pathname:使用ListFiles方法遍历目录,得到的每一个文件对象 2.File[] listFiles(FilenameFilter filter) java.io.FilenameFilter接口:实现此接口的类实例可用于过滤器文件名 作用:用于过滤文件名称 抽象方法:用来过滤文件的方法 boolean accept(File dir, String name) 测试指定文件是否应该包含在某一文件列表中。 参数: File dir:构造方法中传递的被遍历的目录 String name:使用ListFiles方法遍历目录,获取的每一个文件/文件夹的名称 注意: 两个过滤器接口没有实现类,需要我们自己写实现类,重写过滤的方法accept,在方法中自己定义过滤的规则 */
public class Demo02Filter {
   
    public static void main(String[] args) throws IOException {
   
        File file = new File("C:\\abc");
        getAllFile(file);
    }

    //遍历目录
    public static void getAllFile(File dir){
   
// File[] files = dir.listFiles(new FileFilter() {//传递过滤器对象 使用匿名内部类
// @Override
// public boolean accept(File pathname) {
   
// //过滤规则,pathname是文件夹或者是.java结尾的文件返回true
//
// return(pathname.isDirectory()||pathname.getName().toLowerCase().endsWith(".java"));
// }
// });
            //使用Lambda表达式简化匿名内部类(接口中只有一个抽象方法)
        File[] files = dir.listFiles(pathname->pathname.isDirectory() || pathname.getName().toLowerCase().endsWith(".java"));


// File[] files = dir.listFiles(new FilenameFilter() {//传递过滤器对象 使用匿名内部类
// @Override
// public boolean accept(File dir, String name) {
   
// //过滤规则,pathname是文件夹或者是.java结尾的文件返回true
// return(new File(dir,name).isDirectory()||name.toLowerCase().endsWith(".java"));
// }
// });

        //使用Lambda表达式简化匿名内部类(接口中只有一个抽象方法)
// File[] files = dir.listFiles((dire, name)->
// //过滤规则,pathname是文件夹或者是.java结尾的文件返回true
// new File(dire, name).isDirectory() || name.toLowerCase().endsWith(".java")
// );


        for (File f : files) {
   
            //对遍历得到的File对象f进行判断,判断是否是文件夹
            if(f.isDirectory()){
   
                getAllFile(f);
            }else{
   
                System.out.println(f);
            }
        }
    }
}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/100191.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年5月1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档