1、File文件类

File类(描述具体文件或文件夹的类):是唯一一个与文件本身操作有关的程序类,可完成文件的创建、删除、取得文件信息等操作。但不能对文件的内容进行修改。

(1)File类的基本使用

File类只用于创建文件文身并不对其内容做任何处理。

Java.Io.File是一个普通的类,直接产生实例化对象,要想得到实例化对象则需用到其提供的构造方法。

A. File类中提供的构造方法

public File(String pathname):其中pathname位要传入对象的绝对路径。

public File(String parent, String child):设置父路径和子路径。

B. File类中的普通方法

判断文件是否存在:public boolean exists()

创建文件:public boolean createNewFile()

删除文件:public boolean delete()


  1. package myIO;
  2. import java.io.File;
  3. import java.io.IOException;
  4. public class Test {
  5. public static void main(String[] args) {
  6. //定义要操作文件的路径
  7. File file = new File("C:\\Users\\lenovo\\Desktop\\TestIo.java");
  8. //查找指定文件是否存在(不存在返回false,反之亦然)
  9. System.out.println(file.exists());
  10. try {
  11. //若指定文件不存在,则创建新文件
  12. file.createNewFile();
  13. //创建文件后打印文件是否存在
  14. System.out.println(file.exists());
  15. } catch (IOException e) {
  16. e.printStackTrace();
  17. }
  18. //对文件进行删除
  19. file.delete();
  20. //进行删除操作后打印文件是否存在
  21. System.out.println("执行删除操作后文件存在与否?");
  22. System.out.println(file.exists());
  23. }
  24. }


  1. /*
  2. * 实现程序:文件不存在则创建,存在则删除
  3. * */
  4. public class Test{
  5. public static void main(String[] args) throws IOException {
  6. File file = new File("C:\\\\Users\\\\lenovo\\\\Desktop\\\\TestIo.java");
  7. if(!file.exists()) {
  8. file.createNewFile();
  9. }else {
  10. file.delete();
  11. }
  12. }
  13. }

上述方法应该是最简化的文件处理操作了,但是仍然存在问题:如Linux下文件路径的分隔符用“/”,而在windows下则用的是“\”;但是即便这样也不影响跨平台性,我们可以引入File类的一个常量"public static final String separator "来对其描述。


  1. public class Test{
  2. public static void main(String[] args) throws IOException {
  3. //利用File类的常量来设置不同操作系统下的分隔符
  4. //separator由不同操作系统下的JVM来决定到底是"/"还是"\"
  5. String singal = File.separator;
  6. File file = new File("C"+singal+"Users"+singal+"lenovo"
  7. +singal+"Desktop"+singal+"TestIO.java");
  8. System.out.println(file.exists());
  9. if(file.exists()) {
  10. file.createNewFile();
  11. }else {
  12. file.delete();
  13. }
  14. }
  15. }

在Java中要进行文件的处理操作是要通过本地操作系统支持的,在这之中如果操作的是同名文件,就可能出现延迟的问题。(开发之中尽可能避免文件重名问题)

(2)目录操作

取得父路径:public String getParent() 返回当前的父路径

取得父File对象:public File getParentFile() 返回当前的父File对象

创建父目录: public boolean mkdirs() 有多少级就创建多少级


  1. public class Test{
  2. public static void main(String[] args) throws IOException {
  3. String singal = File.separator;
  4. File file = new File("G:"+singal+"lemon"+singal+"javaIO"
  5. +singal+"TestIO.java");
  6. if(!file.getParentFile().exists()) {
  7. file.mkdirs();
  8. }
  9. }
  10. }

若使用file.mkdirs()创建,则创建的为文件夹。而若使用file。getParentFile.mkdirs()创建时则为目录。


  1. public class Test{
  2. public static void main(String[] args) throws IOException {
  3. String singal = File.separator;
  4. File file = new File("G:"+singal+"lemon"+singal+"javaIO"
  5. +singal+"TestIO.java");
  6. //判断父目录是否存在
  7. if(!file.getParentFile().exists()) {
  8. file.getParentFile().mkdirs();
  9. }
  10. }
  11. }


  1. public class Test{
  2. public static void main(String[] args) throws IOException {
  3. String singal = File.separator;
  4. File file = new File("G:"+singal+"lemon"+singal+"javaIO"
  5. +singal+"TestIO.java");
  6. //返回当前的父路径
  7. System.out.println("返回当前的父路径");
  8. System.out.println(file.getParent());
  9. //返回当前父File对象
  10. System.out.println("返回当前父File");
  11. System.out.println(file.getParentFile());
  12. //判断父目录是否存在
  13. if(!file.getParentFile().exists()) {
  14. //创建多级目录
  15. file.getParentFile().mkdirs();
  16. }
  17. //若文件存在则删除
  18. if(file.exists()) {
  19. file.delete();
  20. }else {
  21. //文件不存在,则创建新文件
  22. file.createNewFile();
  23. }
  24. }

()取得文件信息

判断路径是否是文件: public boolean isFile()

判断路径是否是目录: public boolean isDirectory()

取得文件大小(字节):  public long length()

最后一次修改日期 : public long lastModified()


  1. /*
  2. * 取得文件信息
  3. * */
  4. public class Test{
  5. public static void main(String[] args) {
  6. String singal = File.separator;
  7. File file = new File("G:"+singal+"lemon"+singal+"javaIO"
  8. +singal+"TestIO.java");
  9. //判断上级目录是否为文件
  10. System.out.println("上级目录是否为文件?");
  11. System.out.println(file.getParentFile().isFile());
  12. //判断当前目录是否为文件
  13. System.out.println("该目录下是否为文件?");
  14. System.out.println(file.isFile());
  15. //查看当前对象是否为路径
  16. System.out.println("当前对象为路径?");
  17. System.out.println(file.isDirectory());
  18. //取得文件的大小
  19. System.out.println("当前文件的大小为:");
  20. long length = file.length();
  21. System.out.println(length);
  22. //取得文件的最后修改日期
  23. System.out.println("当前文件的最后修改日期为:");
  24. long date = file.lastModified();
  25. System.out.println(date);
  26. }
  27. }

取得本地文件的相关信息:


  1. /*
  2. * 列出当前目录下所有的文件
  3. * */
  4. public class Test{
  5. public static void main(String[] args) {
  6. String singal = File.separator;
  7. //要操作的文件
  8. File file = new File("C:"+singal+"Users"+singal+"lenovo");
  9. //保证是目录且存在
  10. if(file.exists()&&file.isDirectory()) {
  11. File[] result = file.listFiles();
  12. for (File file2 : result) {
  13. System.out.println(file2);
  14. }
  15. }
  16. }
  17. }

我们不难发现根据File类提供的listFiles可以取得本地文件的信息,但是这样只能取得第一级目录下的相关信息。若我们想要取得所有级的信息,则需要我们自己进行递归操作处理。


  1. /*
  2. * 打印当前目录下所有层级的文件信息
  3. * */
  4. public class Test{
  5. public static void main(String[] args) {
  6. String singal = File.separator;
  7. //要操作的文件
  8. File file = new File("D:"+singal+"Users"+singal+"lenovo");
  9. listAllFileInfor(file);
  10. }
  11. public static void listAllFileInfor(File file) {
  12. if(file.isDirectory()) {
  13. //file对象是目录,列出子目录的信息
  14. File[] files = file.listFiles();
  15. for (File file2 : files) {
  16. //进行递归,
  17. listAllFileInfor(file2);
  18. }
  19. }else {
  20. //当前操作的不是目录
  21. System.out.println(file);
  22. }
  23. }
  24. }

现在所有的代码都在main线程中执行,可以发现只有当listAllFileInfor没有执行完,main的后续操作也无法完成。正是因为这种耗时操作使得主线程出现了阻塞,而导致后续代码无法直接正常执行完毕。若不想让其别阻塞,我们需要重新起一个线程来对其进行操作。


  1. /*
  2. * 解决阻塞main线程,另起线程
  3. * */
  4. public class Test{
  5. public static void main(String[] args) {
  6. new Thread(()->{
  7. String singal = File.separator;
  8. //要操作的文件
  9. File file = new File("G:"+singal+"lenmon");
  10. listAllFileInfor(file);
  11. },"输出线程").start();
  12. System.out.println("main执行完毕");
  13. }
  14. public static void listAllFileInfor(File file) {
  15. if(file.isDirectory()) {
  16. //file对象是目录,列出子目录的信息
  17. File[] files = file.listFiles();
  18. for (File file2 : files) {
  19. //进行递归,
  20. listAllFileInfor(file2);
  21. }
  22. }else {
  23. //当前操作的不是目录
  24. System.out.println(file);
  25. }
  26. }
  27. }


JavaIO——File类的更多相关文章

  1. JavaIO之File类

    Java-IO之File类 Java-IO之File类 1. File类 1.1. File类说明 1.2. 体验 File 类 1.3. 构造一个 File 类实例: 1.4. 路径: 1.4.1. ...

  2. java基础知识回顾之javaIO类--File类应用:过滤器接口FilenameFilter和FileFilter

    FilenameFilter和FileFilter都是用来过滤文件,例如过滤,以.jpg或者.java结尾的文件,通过看他们的源码:通过使用File类中String[] list(FilenameFi ...

  3. java基础知识回顾之javaIO类--File类

    File类是对文件系统中文件以及目录(文件夹)进行封装的对象,可以通过面向对象的思想来操作文件和目录(文件夹).File类保存文件或目录的各种元素的信息,包括文件名,文件长度,最后修改日期,是否可读, ...

  4. JavaIO(01)File类详解

    File类 file类中的主要方法和变量   常量: 表示路径的分割符:(windows) 作用:根据java可移植性的特点,编写路径一定要符合本地操作系统要求的分割符: public static ...

  5. JavaIO流——File类

    1.掌握File 类的作用 2.可以使用File 类中的方法对文件进行操作 所有的 io 操作都保存在 java.io 包中. 构造方法:public File (String pathname) 直 ...

  6. Java基础---Java---IO流-----File 类、递归、删除一个带内容的目录、列出指定目录下文件夹、FilenameFilte

    File 类 用来将文件或者文件夹封装成对象 方便对文件与文件夹进行操作. File对象可以作为参数传递给流的构造函数 流只用操作数据,而封装数据的文件只能用File类 File类常见方法: 1.创建 ...

  7. 总结JAVA----IO流中的File类

    对于IO流中File类的总结 File类的基本概念 File类只能用于完成对于文件属性(是否存在.可读性.长度)的一些操作,不能用于文件的访问. File类的对象 File类的对象存储的是文件的绝对路 ...

  8. javaIO流(一)--File类的基本使用

    一.File文件操作类 在java语言中提供有对于文件操作系统的支持,这个支持就在java.io.File类中进行了定义,也就是说在整个java.io包中File类是唯一一个与文件本身操作有关的类(创 ...

  9. 吴裕雄--天生自然JAVAIO操作学习笔记:File类

    import java.io.File ; import java.io.IOException ; public class FileDemo01{ public static void main( ...

随机推荐

  1. Linux网卡bond模式

    Bond模式 交换机配置 mode=0 balance-rr 轮询均衡模式 LACP mode on 强制链路聚合 mode=1 active-backup 主备模式 无 mode=2 balance ...

  2. cloudstack部署

    参考文档 https://blog.csdn.net/u012124304/article/details/80960504#Mysql_37 cloudstack的rpm包下载地址 http://d ...

  3. 八. Go并发编程--errGroup

    一. 前言 了解 sync.WaitGroup的用法都知道 一个 goroutine 需要等待多个 goroutine 完成和多个 goroutine 等待一个 goroutine 干活时都可以解决问 ...

  4. glibc memcpy() 源码浅谈

    其实我本来只是想搞懂为什么memcpy()函数的参数类型是void *的: 我以为会在memcpy()源码中能找到答案,其实并没有,void *只是在传递参数的时候起了作用,可以让memcpy()接受 ...

  5. split,cdn,shell脚本,tmux,记一次往国外服务器传大文件的经历

    需求是这样的:将一个大概680M的Matlab数据文件传到国外某所大学的服务器上,服务器需要连接VPN才能访问,由于数据文件太大,而且如果我直接ssh连过去或者用ftp传输,那么中间很可能中断. ps ...

  6. Spring Cache 带你飞(二)

    接着上一篇讲了 Spring Cache 如何被 Spring Aop 代理加载对应的代码,以及何如注入相关界面逻辑. Spring Cache 带你飞(一) 本篇我们围绕两个要点展开: 一个数据是如 ...

  7. (四)DQL查询数据(最重点)

    4.1   DQL Data Query Language 数据查询语言 1   所有的查询操作都用它  Select 2   简单的查询,复杂的查询它都能做 3   数据库中最核心的语言,最重要的语 ...

  8. Java学习(十二)

    今天安装讲师推荐下载了一个叫Hbuiler X的IDE,并且学习了选择器的知识. 作为练习,写了一下的代码 <!DOCTYPE html> <html> <head> ...

  9. 问题 C: A+B Problem II

    题目描述 I have a very simple problem for you. Given two integers A and B, your job is to calculate the ...

  10. 痞子衡嵌入式:在IAR开发环境下RT-Thread工程函数重定向失效分析

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是在IAR开发环境下RT-Thread工程函数重定向失效分析. 痞子衡旧文 <在IAR下将关键函数重定向到RAM中执行的方法> ...