Java学习记录(十三)File类

File的创建方法

File有三种创建方法,其根本都是将字符串传递给File类用来创建File类型的对象

第一种直接传入字符串创建File对象

下列就为直接将文件地址当作一个字符串直接传入File类创建对象

java 复制代码
//文件的创建
        File f = new File("D:\\Test\\aTest.txt");
        System.out.println(f);

第二种将父文件夹和本身分割开,再拼接创建File对象

java 复制代码
//文件的拼接创建,格式为在创建文件对象时传入夫文件名和本文件的名字new File(parent,son);
        String parent = "D:\\Test";
        String son = "aTest.txt";
        File f1 = new File(parent,son);

第三种先创建父文件夹对象,再用字符串的形式传入本文件,进行创建File类

java 复制代码
//用字符串的方式拼接
        File f2 = new File("D:\\Test");
        String sonname = "aTest.txt";
        File f3 = new File(f2,sonname);
        System.out.println(f3);

File常见的成员方法

判断获取方法

创建删除方法

获取并遍历该文件夹

练习

下面是一个对于上面方法相关小练习,要求查找一个文件夹下所有以.txt和.avi结尾的文件,并打印出他们的个数,这道题会用到递归思想

java 复制代码
package com.itazhang.Demo1;

import java.io.File;

public class FileExercise3 {
    static int count1 = 0;
    static int count2 = 0;
    public static void main(String[] args) {
        File f = new File("D:\\11Codingtext\\Myfile\\aaa");
        find(f);
        System.out.println(".txt结尾的文件有"+count1+"个");
        System.out.println(".avi结尾的文件有"+count2+"个");

    }
    public static void find(File file){
        File[] listFiles = file.listFiles();
        for (File listFile : listFiles) {
            //判断是否为文件
            if(listFile.isFile()){
                if(listFile.getName().endsWith(".txt")){
                    count1++;
                }
                else if(listFile.getName().endsWith(".avi")){
                    count2++;
                }
            }else{
                find(listFile);
            }
        }
    }
}

从上图看出,都应该是两个,而在上面代码中不能将count计数器和打印语句放在find方法里,因为会使用到递归,每次进入新的文件夹都会重新调用该方法,这样的话就会每次都将count重新设置为初始值实现不了计数的功能,打印语句放入方法中也会导致每次递归就会打印,所以将count计数器使用静态赋值的方式放在main方法,且将打印方法也放在main方法,这样可以在使用递归的同时满足题目的需求。

相关推荐
zenpluck19 分钟前
RTAB-Map学习记录(1)--论文阅读
c++·论文阅读·学习·机器人
小宋加油啊1 小时前
多模态方法学习
学习·多模态
小猪佩奇TONY1 小时前
OpenCL 学习(4)---- OpenCL 上下文和程序对象
学习
xian_wwq1 小时前
【学习笔记】OAuth 2.0 安全攻防:从 Portswigger 六大实验看认证漏洞挖掘
笔记·学习·安全
babe小鑫2 小时前
大数据运维与管理专业学习数据分析的必要性
大数据·运维·学习
2501_901147832 小时前
粉刷房子问题:从DP基础到空间极致优化学习笔记
笔记·学习·动态规划
im_AMBER2 小时前
Leetcode 122 二叉树的最近公共祖先 | 二叉搜索树迭代器
学习·算法·leetcode·二叉树
CappuccinoRose2 小时前
CSS 语法学习文档(十一)
前端·css·学习·表单控件
随意起个昵称3 小时前
Dijstra算法学习笔记
笔记·学习·算法
星火开发设计3 小时前
C++ 异常处理:try-catch-throw 的基本用法
java·开发语言·jvm·c++·学习·知识·对象