一、File类
1.概述
-
java.io.File类: 文件和目录路径名的抽象表示形式。
-
java把电脑中的文件和文件夹(目录)封装为了一个File类,我们可以使用File类对文件和文件夹进行操作
-
我们可以使用File类的方法:
- 创建一个文件/文件夹
- 删除文件/文件夹
- 获取文件/文件夹
- 判断文件/文件夹是否存在
- 对文件夹进行遍历
- 获取文件的大小
-
File类是一个与系统无关的类,任何的操作系统都可以使用这个类中的方法
2.File类的静态成员变量
2.1路径分隔符
- static String pathSeparator 与系统有关的路径分隔符,为了方便,它被表示为一个字符串。
- static char pathSeparatorChar 与系统有关的路径分隔符。
String pathSeparator = File.pathSeparator;
System.out.println(pathSeparator);//路径分隔符 windows:分号; linux:冒号:
2.2名称分隔符
static String separator
与系统有关的默认名称分隔符,为了方便,它被表示为一个字符串。static char separatorChar
与系统有关的默认名称分隔符。
2.3使用建议
- 操作路径:路径不能写死了
C:\develop\a\a.txt windows
C:/develop/a/a.txt linux
"C:"+File.separator+"develop"+File.separator+"a"+File.separator+"a.txt"
3.绝对路径和相对路径
3.1绝对路径
- 绝对路径:是一个完整的路径
- 以盘符(c:,D:)开始的路径
c:\\a.txt
C:\\Users\\IdeaProjects\\shungyuan\\123.txt
3.2相对路径
- 相对路径:是一个简化的路径
- 相对指的是相对于当前项目的根目录(C:\Users\IdeaProjects\shungyuan)
- 如果使用当前项目的根目录,路径可以简化书写
C:\\Users\itcast\\IdeaProjects\\shungyuan\\123.txt
–>简化为:123.txt
(可以省略项目的根目录)
3.3注意事项
- 1.路径是不区分大小写
- 2.路径中的文件名称分隔符windows使用反斜杠,反斜杠是转义字符,两个反斜杠代表一个普通的反斜杠
4.File类的构造方法
4.1构造方法1
File(String pathname)
通过将给定路径名字符串转换为抽象路径名来创建一个新File
实例。
String pathname
:字符串的路径名称- 路径可以是以文件结尾,也可以是以文件夹结尾
- 路径可以是相对路径,也可以是绝对路径
- 路径可以是存在,也可以是不存在
- 创建
File
对象,只是把字符串路径封装为File
对象,不考虑路径的真假情况
4.1使用实例
4.2构造方法2
/*
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
}
4.3构造方法3
/*
File(File parent, String child) 根据 parent 抽象路径名和 child 路径名字符串创建一个新 File 实例。
参数:把路径分成了两部分
File parent:父路径
String child:子路径
好处:
父路径和子路径,可以单独书写,使用起来非常灵活;父路径和子路径都可以变化
父路径是File类型,可以使用File的方法对路径进行一些操作,再使用路径创建对象
*/
private static void show03(){
File parent = new File("d:\\");
File file = new File(parent,"a.txt");
System.out.println(file);
}
5.File的常用方法
5.1获取
5.1.1获取绝对路径
/*
public String getAbsolutePath() :返回此File的绝对路径名字符串。
获取的构造方法中传递的路径
无论路径是绝对的还是相对的,getAbsolutePath方法返回的都是绝对路径
*/
private static void show01(){
File f1 = new File("D:\\Users\\xiaopangtou\\OneDrive\\project_web_idea\\j2se");
String absolutePath = f1.getAbsolutePath();
System.out.println(absolutePath);
File f2 = new File("c.txt");
String absolutePath1 = f2.getAbsolutePath();
System.out.println(absolutePath1);
}
5.1.2获取路径本身
/*
public String getPath() :将此File转换为路径名字符串。
获取的构造方法中传递的路径
toString方法调用的就是getPath方法
源码:
public String toString() {
return getPath();
}
*/
private static void show02(){
File f1 = new File("D:\\Users\\xiaopangtou\\OneDrive\\project_web_idea\\j2se");
String path = f1.getPath();
System.out.println(path);
File f2 = new File("a.txt");
System.out.println(f2.getPath());
}
5.1.3获取给定路径的结尾部分
/*
public String getName() :返回由此File表示的文件或目录的名称。
获取的就是构造方法传递路径的结尾部分(文件/文件夹)
*/
private static void show03(){
File f1 = new File("D:\\Users\\xiaopangtou\\OneDrive\\project_web_idea\\j2se");
String name = f1.getName();
System.out.println(name);
File f2 = new File("D:\\Users\\xiaopangtou\\OneDrive\\project_web_idea\\j2se\\a.txt");
System.out.println(f2.getName());
}
5.1.4获取文件大小
/*
public long length() :返回由此File表示的文件的长度。
获取的是构造方法指定的文件的大小,以字节为单位
注意:
文件夹是没有大小概念的,不能获取文件夹的大小
如果构造方法中给出的路径不存在,那么length方法返回0
*/
private static void show04() {
File f1 = new File("C:\\develop\\a\\1.jpg");
long l1 = f1.length();
System.out.println(l1);//780831字节
File f2 = new File("C:\\develop\\a\\2.jpg");
System.out.println(f2.length());//0
File f3 = new File("C:\\develop\\a");
System.out.println(f3.length());//0 文件夹没有大小概念的
}
5.2判断
5.2.1判断文件是否存在
/*
public boolean exists() :此File表示的文件或目录是否实际存在。
用于判断构造方法中的路径是否存在
存在:true
不存在:false
*/
private static void show01() {
File f1 = new File("C:\\Users\\IdeaProjects\\shungyuan");
System.out.println(f1.exists());//true
File f2 = new File("C:\\Users\\IdeaProjects\\shung");
System.out.println(f2.exists());//false
File f3 = new File("shungyuan.iml");//相对路径 C:\Users\itcast\IdeaProjects\shungyuan\shungyuan.iml
System.out.println(f3.exists());//true
File f4 = new File("a.txt");
System.out.println(f4.exists());//false
}
5.2.2判断文件路径结尾的类型
/*
public boolean isDirectory() :此File表示的是否为目录。
用于判断构造方法中给定的路径是否以文件夹结尾
是:true
否:false
public boolean isFile() :此File表示的是否为文件。
用于判断构造方法中给定的路径是否以文件结尾
是:true
否:false
注意:
电脑的硬盘中只有文件/文件夹,两个方法是互斥
这两个方法使用前提,路径必须是存在的,否则都返回false
*/
private static void show02() {
File f1 = new File("C:\\Users\\IdeaProjects\\shung");
//不存在,就没有必要获取
if(f1.exists()){
System.out.println(f1.isDirectory());
System.out.println(f1.isFile());
}
File f2 = new File("C:\\Users\\IdeaProjects\\shungyuan");
if(f2.exists()){
System.out.println(f2.isDirectory());//true
System.out.println(f2.isFile());//false
}
File f3 = new File("C:\\Users\\IdeaProjects\\shungyuan\\shungyuan.iml");
if(f3.exists()){
System.out.println(f3.isDirectory());//false
System.out.println(f3.isFile());//true
}
}
5.3创建和删除文件
5.3.1创建文件方法
/*
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:\\Users\\xiaopangtou\\OneDrive\\project_web_idea\\j2se\\a.txt");
boolean newFile = f1.createNewFile();
System.out.println(newFile);
File f2 = new File("2.txt");
System.out.println(f2.createNewFile());
File f3 = new File("新建文件夹");
System.out.println(f3.createNewFile());//不要被名称迷糊,要看类型
//
File f4 = new File("j2s\\d.txt");//错误的文件夹
System.out.println(f4.createNewFile());//报错路径不存在,抛出IOException
}
5.3.2创建文件夹
/*
public boolean mkdir() :创建单级空文件夹
public boolean mkdirs() :既可以创建单级空文件夹,也可以创建多级文件夹
创建文件夹的路径和名称在构造方法中给出(构造方法的参数)
返回值:布尔值
true:文件夹不存在,创建文件夹,返回true
false:文件夹存在,不会创建,返回false;构造方法中给出的路径不存在返回false
注意:
1.此方法只能创建文件夹,不能创建文件
*/
private static void show02() {
File file = new File("src\\FileAndIO\\aaa");
boolean mkdir = file.mkdir();
System.out.println(mkdir);
File f2 = new File("src\\FileAndIO\\111\\222\\333\\444");
boolean b2 = f2.mkdirs();//创建多级文件夹
System.out.println("b2:"+b2);
File f3 = new File("src\\FileAndIO\\aaa.txt");
boolean b3 = f3.mkdirs();//创建多级文件夹
System.out.println("b3:"+b3);
File f4 = new File("src\\FileAndI\\aaa.txt");
boolean b4 = f4.mkdirs();//不会抛出异常,路径不存在,不会创建
System.out.println("b4:"+b4);
}
5.3.3删除文件/文件夹
/*
public boolean delete() :删除由此File表示的文件或目录。
此方法,可以删除构造方法路径中给出的文件/文件夹
返回值:布尔值
true:文件/文件夹删除成功,返回true
false:文件夹中有内容,不会删除返回false;构造方法中路径不存在false
注意:
delete方法是直接在硬盘删除文件/文件夹,不走回收站,删除要谨慎
*/
private static void show03() {
File f1 = new File("FileAndIO\\aaa.txt");
boolean delete = f1.delete();
System.out.println(delete);
File f2 = new File("FileAndIO");
boolean delete1 = f2.delete();
System.out.println(delete1);
}
6.File类遍历目录方法
/*
public File[] listFiles() :返回一个File数组,表示该File目录中的所有的子文件或目录。
遍历构造方法中给出的目录,会获取目录中所有的文件/文件夹,把文件/文件夹封装为File对象,多个File对象存储到File数组中
*/
private static void show02() {
File file = new File("D:\\Users\\xiaopangtou\\OneDrive\\project_web_idea\\j2se\\src\\FileAndIO");
File[] files = file.listFiles();
for (File file1 : files) {
System.out.println(file1);
}
}
/*
public String[] list() :返回一个String数组,表示该File目录中的所有子文件或目录。
遍历构造方法中给出的目录,会获取目录中所有文件/文件夹的名称,把获取到的多个名称存储到一个String类型的数组中
*/
private static void show01() {
// //注意事项1:不能遍历文件
// File file = new File("D:\\Users\\xiaopangtou\\OneDrive\\project_web_idea\\j2se\\src\\FileAndIO\\a.txt");
// //注意不能遍历 不存在的路径
// File file = new File("D:\\Users\\xiaopangtou\\OneDrive\\project_web_idea\\j2se\\src\\FileAn");
File file = new File("D:\\Users\\xiaopangtou\\OneDrive\\project_web_idea\\j2se\\src\\FileAndIO");
String[] list = file.list();
for (String string : list) {
System.out.println(string);
}
}
二递归
1.分类
- 直接递归称为方法自身调用自己。
- 间接递归可以A方法调用B方法,B方法调用C方法,C方法调用A方法。
2.注意
2.1递归没有出口导致栈内存溢出
2.2递归次数太多导致栈内存溢出
2.3栈内存溢出原理分析
2.4使用递归的注意点
- 必须有出口
- 必须考虑递归的深度,不能太深
3.递归打印多级目录
3.1遍历方法的分析
3.2递归方法的实现
private static void getAllFiles2(File dir){
File[] files = dir.listFiles();
for (File file : files) {
System.out.println(file);
//如果该文件是目录 则继续递归下去进行访问
if (file.isDirectory()){
getAllFiles2(file);
}
}
}
4.文件搜索
在指定目录下搜索指定类型的文件
public static void main(String[] args) {
getAllFiles(new File("C:\\abc"));
}
private static void getAllFiles(File dir){
File[] files = dir.listFiles();
for (File file : files) {
if (file.isDirectory()){
getAllFiles(file);
}else {
//如果是文件 则判断是否以.java结尾
//首先获取文件名
String name = file.getName();
name = name.toLowerCase();//忽略大小写
if (name.endsWith(".java")){
System.out.println(file);
}
}
}
}
三、文件过滤器
1.java.io.FileFilter接口
1.1简介
- 在
File
类中有两个和ListFiles重载的方法,方法的参数传递的就是过滤器 java.io.FileFilter
接口:用于抽象路径名(File对象)的过滤器。- 作用:用来过滤文件(
File
对象) - 抽象方法:用来过滤文件的方法
boolean accept(File pathname)
File pathname
:使用ListFiles
方法遍历目录,得到的每一个文件对象
- 作用:用来过滤文件(
1.2注意点
- 接口是没有实现类的,需要我们自己写实现类,重写过滤的方法accept,在方法中自己定义过滤的规则
1.3过滤器实现打印多级目录的原理分析
1.4过滤器实现搜索指定文件
重写规则即可
1.4.1匿名内部类来实现简化
public class Demo03Filter {
public static void main(String[] args) {
File file = new File("c:\\abc");
getAllFile(file);
}
private static void getAllFile(File dir){
File[] files = dir.listFiles(new FileFilter() {
@Override
public boolean accept(File pathname) {
if (pathname.isDirectory()){
return true;
}
String name = pathname.getName();
name = name.toLowerCase();
if (name.endsWith(".java")){
return true;
}
return false;
}
});//传递过滤器对象
for (File f : files) {
if(f.isDirectory()){
// System.out.println(f);
getAllFile(f);
}else{
System.out.println(f);
}
}
}
}
1.2 java.io.FilenameFilter接口
只是参数不同,但是实现原理和上述一致
- 作用:用于过滤文件名称
- 抽象方法:用来过滤文件的方法
- boolean accept(File dir, String name)
- File dir:构造方法中传递的被遍历的目录
- String name:使用ListFiles方法遍历目录,获取的每一个文件/文件夹的名称
1.2基本使用
public class Demo04Filter {
public static void main(String[] args) {
File file = new File("c:\\abc");
getAllFile(file);
}
private static void getAllFile(File dir){
File[] files = dir.listFiles(new FilenameFilter() {
@Override
public boolean accept(File dir, String name) {
//先把dir 和 name封装为一个file对象
return new File(dir,name).isDirectory() || name.toLowerCase().endsWith(".java");
}
});//传递过滤器对象
for (File f : files) {
if(f.isDirectory()){
// System.out.println(f);
getAllFile(f);
}else{
System.out.println(f);
}
}
}
}