文件操作和IO(2):Java中操作文件

简介: 文件操作和IO(2):Java中操作文件

 本章内容,主要涉及文件的元信息、路径的操作,并不存在对文件的读写操作。

       Java通过 java.io.File 类来对一个文件(包括目录)进行抽象的描述。注意:有File对象并不意味着真实存在该文件。

以下是对File的概述:


一、File的属性


修饰符及类型 属性 说明
static String pathSeparator 依赖于系统的路径分隔符,String
类型的表示
static char pathSeparatorChar 依赖于系统的路径分隔符,char类

这里路径直接的分隔符是根据系统自动调整的,在开发过程中还是更推荐使用正斜杠 “ / ”。windows也支持正斜杠。


二、File的构造方法


签名 说明
File(File parent, String child) 根据父目录 + 孩子文件路径,创建⼀个新的 File 实例
File(String pathname) 根据文件路径创建⼀个新的 File 实例,路径可以是绝
对路径或者相对路径
File(String parent, String child) 根据父目录 + 孩子文件路径,创建⼀个新的 File 实
例,父目录用路径表示

这里主要介绍中间的构造方法,中间的是最常用的。注意:这里的决定路径有两种情况:

       1、如果是在idea中运行程序,此时工作目录就是在项目所在的目录。

       2、如果把代码打包成一个jar包,此时工作目录就是在jar包所在目录。


三、File的方法


修饰符及返回值类型 方法签名 说明
String getParent() 返回 File 对象的⽗⽬录⽂件路径
String getName() 返回 FIle 对象的纯⽂件名称
String getPath() 返回 File 对象的⽂件路径
String getAbsolutePath() 返回File 对象的绝对路径
String getCanonicalPath() 返回 File 对象的修饰过的绝对路径
boolean exists() 判断 File 对象描述的⽂件是否真实
存在
boolean                          isDirectory()                   判断 File 对象代表的⽂件是否是⼀个⽬录
boolean isFile() 判断 File 对象代表的⽂件是否是⼀
个普通⽂件
boolean createNewFile() 根据 File对象,⾃动创建⼀个空⽂
件。成功创建后返回 true
boolean delete() 根据 File 对象,删除该⽂件。成功
删除后返回 true 
void deleteOnExit() 根据 File 对象,标注⽂件将被删
除,删除动作会到 JVM 运⾏结束时
才会进⾏
String[] list() 返回 File 对象代表的⽬录下的所有
⽂件名
File[] listFiles() 返回 File 对象代表的⽬录下的所有
⽂件,以 File 对象表⽰
boolean mkdir() 创建 File 对象代表的⽬录
boolean mkdirs() 创建 File 对象代表的⽬录,如果必
要,会创建中间⽬录
boolean renameTo(File dest) 进⾏⽂件改名,也可以视为我们平
时的剪切、粘贴操作
boolean canRead() 判断⽤⼾是否对⽂件有可读权
boolean canWrite() 判断⽤⼾是否对⽂件有可写权限


四、代码示例


1、getName,getParent,getPath方法

绝对路径的File对象,代码如下

public class IODemo1 {
 public static void main(String[] args) {
 //指定文件的路径
 File f1 = new File("C:/IOTest/test.txt");//绝对路径
        System.out.println(f1.getPath());//返回File对象的⽂件路径
         System.out.println(f1.getParent());//返回 File 对象的⽗⽬录⽂件路径
         System.out.println(f1.getName());//返回 FIle 对象的纯⽂件名称
     }
 }

执行结果:

相对路径的File对象,代码如下

 public class IODemo1 {
 public static void main(String[] args) {
 //指定文件的路径
 File f1 = new File("./test.txt");//绝对路径
         System.out.println(f1.getPath());//返回File对象的⽂件路径
         System.out.println(f1.getParent());//返回 File 对象的⽗⽬录⽂件路径
         System.out.println(f1.getName());//返回 FIle 对象的纯⽂件名称
     }
 }

执行结果:

2、getAbsolutePath,getCanonicalPath方法

使用绝对路径创造一个File对象,代码如下

 public class IODemo2 {
 public static void main(String[] args) throws IOException {
 File f = new File("C:/IOTest/test.txt");//绝对路径
         System.out.println(f.getAbsolutePath());//返回File对象的绝对路径
         System.out.println(f.getCanonicalPath());//返回File对象的修饰过的绝对路径
     }
 }

执行结果:

使用相对路径创建File对象,代码如下:

 public class IODemo2 {
 public static void main(String[] args) throws IOException {
 File f = new File("./test.txt");//绝对路径
         System.out.println(f.getAbsolutePath());//返回File对象的绝对路径
         System.out.println(f.getCanonicalPath());//返回File对象的修饰过的绝对路径
     }
 }

执行结果:

可以看出,上面方法在绝对路径中没有啥差别,但在相对路径的就有些许差别。getCanonicalPath返回File对象的修饰过的绝对路径,也就没有了点 ' . ' 修饰。

3、exists,isDirectory,createNewFile方法

使用相对路径创建File对象,代码如下:

 public class IODemo3 {
 public static void main(String[] args) {
 File f = new File("./test.txt");
 boolean ret1 = f.exists();//判断 File 对象描述的⽂件是否真实存在
 boolean ret2 = f.isDirectory();//判断 File 对象代表的⽂件是否是⼀个⽬录
 boolean ret3 = f.isFile();//判断 File 对象代表的⽂件是否是⼀个普通⽂件
         System.out.println(ret1);
         System.out.println(ret2);
         System.out.println(ret3);
     }
 }

执行结果:

4、createNewFile,delete,deleteOnExit

先创造出一个文件,使用createNewFile方法,代码如下:

public class IODemo4 {
    public static void main(String[] args) throws IOException {
        File f = new File("./test.txt");
        boolean ret1 = f.createNewFile();//根据 File对象,⾃动创建⼀个空⽂件。成功创建后返回 true
        System.out.println(ret1);
    }
}

执行代码前:

执行代码后:

多了test.txt文件

delete方法删除test.txt文件,代码如下:

public class IODemo4 {
    public static void main(String[] args) throws IOException {
        File f = new File("./test.txt");
        boolean ret1 = f.createNewFile();//根据 File对象,⾃动创建⼀个空⽂件。成功创建后返回 true
        System.out.println(ret1);
        boolean ret = f.delete();//根据 File 对象,删除该⽂件。成功删除后返回 true 
        System.out.println(ret);
    }
}

执行结果:

test.txt文件没有了。

deleteOnExit方法,在程序执行完后才会删除指定的文件,代码如下:

public class IODemo4 {
    public static void main(String[] args) throws IOException, InterruptedException {
        File f = new File("./test.txt");
        boolean ret1 = f.createNewFile();//根据 File对象,⾃动创建⼀个空⽂件。成功创建后返回 true
        System.out.println(ret1);//根据 File 对象,标注⽂件将被删除,删除动作会到 JVM 运⾏结束时才会进⾏
        f.deleteOnExit();
        Thread.sleep(5000);
    }
}

执行前:

有test.txt文件。

执行后:

过5秒后才会删除test.txt文件。

5、list,listFiles,mkdir,mkdirs,renameTo方法

list:

代码如下:

public class IODemo5 {
    public static void main(String[] args) {
        File f = new File(".");
        String[] files = f.list();//返回 File 对象代表的⽬录下的所有⽂件名
        System.out.println(Arrays.toString(files));
    }
}

执行结果:

listFiles:

代码如下:

public class IODemo5 {
    public static void main(String[] args) {
//        String[] files = f.list();//返回 File 对象代表的⽬录下的所有⽂件名
//        System.out.println(Arrays.toString(files));
        File f = new File(".");
        File[] files = f.listFiles();//返回File对象代表的⽬录下的所有⽂件,以File对象表⽰
        System.out.println(Arrays.toString(files));
    }
}

执行结果:

mkdir:

代码如下:

public class IODemo6 {
    public static void main(String[] args) {
        File f = new File("./aaa");//创建 File 对象代表的⽬录
        boolean ret1 = f.mkdir();
        System.out.println(ret1);
    }
}

执行前:

执行后:

多出了aaa目录。

mkdirs:

代码如下:

public class IODemo7 {
    public static void main(String[] args) {
        File f = new File("./aaa/bbb/ccc");//创建 File 对象代表的⽬录,如果必 要,会创建中间⽬录
        boolean ret = f.mkdirs();
        System.out.println(ret);
    }
}

执行前:

执行后:

当前目录下多了aaa/bbb/ccc。

renameTo:

代码如下:

public class IODemo8 {
    public static void main(String[] args) {
        File src = new File("./test2.txt");
        File dest = new File("./test.txt");
        src.renameTo(dest);//进⾏⽂件改名,也可以视为我们平时的剪切、粘贴操作
    }
}

执行前:

文件名是test.txt。

执行后:

文件名是test2.txt。

除重命名功能外,renameTo还有移动功能(移动比复制、粘贴效率高,前提是在同一硬盘上)。

相关文章
|
1月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
69 9
|
1月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
71 2
|
12天前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
75 34
|
25天前
|
Java
java 中 IO 流
Java中的IO流是用于处理输入输出操作的机制,主要包括字节流和字符流两大类。字节流以8位字节为单位处理数据,如FileInputStream和FileOutputStream;字符流以16位Unicode字符为单位,如FileReader和FileWriter。这些流提供了读写文件、网络传输等基本功能。
42 9
|
29天前
|
消息中间件 存储 Java
RocketMQ文件刷盘机制深度解析与Java模拟实现
【11月更文挑战第22天】在现代分布式系统中,消息队列(Message Queue, MQ)作为一种重要的中间件,扮演着连接不同服务、实现异步通信和消息解耦的关键角色。Apache RocketMQ作为一款高性能的分布式消息中间件,广泛应用于实时数据流处理、日志流处理等场景。为了保证消息的可靠性,RocketMQ引入了一种称为“刷盘”的机制,将消息从内存写入到磁盘中,确保消息持久化。本文将从底层原理、业务场景、概念、功能点等方面深入解析RocketMQ的文件刷盘机制,并使用Java模拟实现类似的功能。
40 3
|
1月前
|
Java 测试技术 Maven
Maven clean 提示文件 java.io.IOException
在使用Maven进行项目打包时,遇到了`Failed to delete`错误,尝试手动删除目标文件也失败,提示`java.io.IOException`。经过分析,发现问题是由于`sys-info.log`文件被其他进程占用。解决方法是关闭IDEA和相关Java进程,清理隐藏的Java进程后重新尝试Maven clean操作。最终问题得以解决。总结:遇到此类问题时,可以通过任务管理器清理相关进程或重启电脑来解决。
|
1月前
|
存储 缓存 安全
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见。本文介绍了使用 `File.createTempFile` 方法和自定义创建临时文件的两种方式,详细探讨了它们的使用场景和注意事项,包括数据缓存、文件上传下载和日志记录等。强调了清理临时文件、确保文件名唯一性和合理设置文件权限的重要性。
71 2
|
1月前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
52 4
|
1月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
51 4
|
1月前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
44 5
下一篇
DataWorks