File类的使用和递归思想

File类

概述

文件: 存储数据

文件夹: 管理文件与文件夹

构造方法

  • public File(String pathname) :通过将给定的路径名字符串转换为抽象路径名来创建新的 File实例。
  • public File(String parent, String child) :从父路径名字符串和子路径名字符串创建新的 File实例。
  • public File(File parent, String child) :从父抽象路径名和子路径名字符串创建新的 File实例。

常用方法

创建方法

  • public boolean createNewFile() : 创建文件,存在返回false,不存在创建文件返回true
  • boolean mkdir() : 创建文件夹,存在返回false,不存在创建文件夹返回true
  • boolean mkdirs() : 创建多级文件夹,存在返回false,不存在创建多级文件夹返回true

删除方法

  • boolean delete() : 删除文件或者文件夹,文件存在返回true,文件不存在返回false;

    可以删除空的文件夹,如果文件夹下有子文件或者子文件夹,删除不掉

判断方法

  • public boolean exists() :此File表示的文件或目录是否实际存在。
  • public boolean isDirectory() :此File表示的是否为目录(文件夹)。
  • public boolean isFile() :此File表示的是否为文件。

路径问题

绝对路径 : 以盘符开头

相对路径 : 相对于本项目

  • public String getAbsolutePath() :返回此File的绝对路径名字符串。
  • public String getParent() : 获取父路径,在创建对象时制定了父路径才能获取,没有指定返回null(相对路径返回null).
  • public String getPath() :将此File转换为路径名字符串(获取构建时的路径)。
  • public String getName() :返回由此File表示的文件或目录的名称。
  • public long length() :返回由此File表示的文件的长度。

高级方法

  • public String[] list() :返回一个String数组,表示该File目录中的所有子文件或目录。
  • public File[] listFiles() :返回一个File数组,表示该File目录中的所有的子文件或目录。

递归

概述

递归就是方法内部自己调用自己.

注意事项

  • 必须有出口,否则会出现栈内存溢出的错误.
  • 递归的次数不宜过多.否则容易出现栈内存溢出
  • 构造方法不能递归

理解

对于递归,可以使用栈来理解,入栈和出栈,对于整个程序的流程,首先,main方法入栈,接着递归方法入栈,方法内调用自己,

继续入栈,知道出口进行返回出栈,层层出栈,这个就是底层的原理吧.

计算n的阶乘

import java.util.Scanner;

/**
* 求n阶乘
* 1.手动输入计算的值
* 2.创建递归方法进行计算
* @author WZLOVE
* @create 2018-07-20 14:34
*/
public class Demo1 { public static void main(String[] args) { Scanner in = new Scanner(System.in); System.out.println("请输入您要计算的值是:");
int n = in.nextInt();
in.close(); long result = getRecursive(n); System.out.println("您输入的值的阶乘计算结果为:" + result); } public static long getRecursive(int n){ // 定义出口
if( n == 1 ){
return 1;
} return n * getRecursive( n - 1 );
}
}

打印多级目录

package com.wzlove.recursive;

import java.io.File;

/**
* 遍历多级目录
*
* @author WZLOVE
* @create 2018-07-20 15:11
*/
public class Demo2 { public static void main(String[] args) { // 程序的健壮性测试
// File file = null;
// File file = new File("E:\\");
// 测试路径
File file = new File("G:\\工作区间\\Intellij IDEA\\JavaSE");
printDirsAndFiles(file);
} public static void printDirsAndFiles(File file){ // 程序的健壮性
if(file == null || !file.exists()){
return ;
} // 如果是文件,直接输出
if(file.isFile()){
System.out.println(file.getAbsolutePath());
} // 如果是文件夹,进行遍历递
File[] files = file.listFiles();
// 如果没有访问权限,直接返回
if(files == null){
return ;
}
for (File file1 : files) { if(file1.isFile()){ System.out.println(file1.getAbsolutePath()); } else { System.out.println(file1.getAbsolutePath()); printDirsAndFiles(file1); } }
}
}

打印某个目录下的所有.java文件

两种方法,第一种:

package com.wzlove.recursive;

import java.io.File;

/**
* 搜索G:\工作区间\Intellij IDEA\JavaSE 目录中的.java 文件。
* 1.创建File的对象,传递File的虚拟路径
* 2.递归方法
* 3.进行健壮性判断:
* * null的判断
* * 文件不存在
* * 如果路径是文件,这三种情况都是直接返回
* * 如果路径合法
* (1) 判断有无权限,有继续向下,无直接返回
* (2) 返回该文件夹下的所有文件和文件夹
* (3) 增强for循环进行遍历
* 如果是文件,判断是否满足要求(递归的出口)
* 如果是文件夹,进行递归调用
*
* @author WZLOVE
* @create 2018-07-20 16:27
*/
public class Demo3 { public static void main(String[] args) {
File file = new File("G:\\工作区间\\Intellij IDEA\\JavaSE");
printAllJavaFiles(file);
} public static void printAllJavaFiles(File file){
if(file == null || !file.exists() || file.isFile()){
return ;
} File[] files = file.listFiles();
if(files == null){
return ;
}
for (File file1 : files) {
if(file1.isFile()){
if(file1.getName().endsWith(".java")){
System.out.println(file1.getAbsolutePath());
}
}else{
printAllJavaFiles(file1);
}
}
} }

第二种,要使用到文件过滤器:

  • File[] listFiles(FileFilter filter) 返回一个抽象路径名数组,表示由此抽象路径名表示的满足指定过滤器的目录中的文件和目录。

      package com.wzlove.recursive;
    
      import java.io.File;
    import java.io.FileFilter; /**
    *
    * @author WZLOVE
    * @create 2018-07-20 16:27
    */
    public class Demo4 { public static void main(String[] args) {
    File file = new File("G:\\工作区间\\Intellij IDEA\\传智播客\\JavaSE");
    printAllJavaFiles(file);
    } public static void printAllJavaFiles(File file){
    if(file == null || !file.exists() || file.isFile()){
    return ;
    } // 使用listFiles(FileFilter)
    /**
    * File[] listFiles(FileFilter filter)
    * 返回一个抽象路径名数组,表示由此抽象路径名表示的满足指定过滤器的目录中的文件和目录。
    */
    File[] files = file.listFiles(new FileFilter() {
    @Override
    public boolean accept(File pathname) {
    if(pathname.isFile() && pathname.getName().endsWith(".java")){
    // 是以.java文件结尾的文件
    return true;
    }
    // 如果是文件夹,也进行返回
    if(pathname.isDirectory()){
    return true;
    }
    // 其余情况返回false
    return false;
    }
    }); for (File file1 : files) {
    if(file1.isFile()){
    System.out.println(file1.getAbsolutePath());
    }else{
    printAllJavaFiles(file1);
    }
    } } }

Java之File与递归的更多相关文章

  1. java基础 File与递归练习 使用文件过滤器筛选将指定文件夹下的小于200K的小文件获取并打印按层次打印(包括所有子文件夹的文件) 多层文件夹情况统计文件和文件夹的数量 统计已知类型的数量 未知类型的数量

    package com.swift.kuozhan; import java.io.File; import java.io.FileFilter; /*使用文件过滤器筛选将指定文件夹下的小于200K ...

  2. Java——使用File类递归遍历指定路劲下的所有文件

    body, table{font-family: 微软雅黑} table{border-collapse: collapse; border: solid gray; border-width: 2p ...

  3. java基础 File 递归删除文件夹中所有文件文件夹 目录(包含子目录)下的.java文件复制到e:/abc文件夹中, 并统计java文件的个数

    File 递归删除文件夹中所有文件文件夹 package com.swift.kuozhan; import java.io.File; import java.util.Scanner; /*键盘录 ...

  4. Java【File类、递归】

    File 1.在io包中 操作电脑中的文件和文件夹 java.io.File 类是文件和目录路径名的抽象表示,主要用于文件和目录的创建.查找和删除等操作. 我们可以使用File类的方法     创建一 ...

  5. Java中如何利用File类递归的遍历指定目录中的所有文件和文件夹

    package cuiyuee; import java.io.File; import java.util.ArrayList; import java.util.List; public clas ...

  6. Java篇-File类之常用操作

    /** * */ package com.io.file; import java.io.File; import java.io.IOException; /** * <pre> * & ...

  7. 使用File类递归列出E盘下全部文件

    import java.io.File;public class FileListTest { public void tree(File file){ if(file.listFiles()!=nu ...

  8. 黑马程序员-File类+递归的简单应用

    Java File类   Java.io.File Java文件类以抽象的方式代表文件名和目录路径名.该类主要用于文件和目录的创建.文件的查找和文件的删除等. File对象代表磁盘中实际存在的文件和目 ...

  9. Java使用线程池递归压缩文件夹下面的所有子文件

    本文将介绍Java中利用线程池递归的方式压缩文件夹下面的所有子文件,具体方法如下: Gzip单个文件压缩 对于单个文件使用GZip压缩. package date0805.demo1; import ...

随机推荐

  1. CHAPTER 5 ‘The Master of Those Who know’ Aristotle 第5章 “有识之士的大师” 亚里士多德

    CHAPTER 5 ‘The Master of Those Who know’ Aristotle 第5章 “有识之士的大师” 亚里士多德 ‘All men by nature desire to ...

  2. [文章存档]Kudu 的 Debug Console 窗口如何查看更多文件

    链接:https://docs.azure.cn/zh-cn/articles/azure-operations-guide/app-service-web/aog-app-service-web-h ...

  3. EOS博彩合约设计

    集中博彩游戏合约设计 一.功能接口 1. 质押deposit 由用户发起,用户将个人账户中token质押给平台,从而可以进入平台去参与平台活动. 2. 赎回withdraw 由用户发起,在用户结束平台 ...

  4. PHP XXE漏洞

    PHP xml 外部实体注入漏洞(XXE) 1.环境 PHP 7.0.30Libxml 2.8.0Libxml2.9.0 以后 ,默认不解析外部实体,对于PHP版本不影响XXE的利用 2.原理介绍 X ...

  5. Flexbox + js实现滑动拼图游戏

    滑动拼图就是把一张图片分成几等份,打乱顺序(下图),然后通过滑动拼凑成一张完整的图片. 要实现一个拼图游戏,需要考虑怎样随机的打乱顺序,怎样交换两张图片的位置,等等.但是,使用了Flexbox布局以后 ...

  6. 分享一个查找linux命令的网站

    http://man.linuxde.net/ 不用每次都找度娘浪费时间了    

  7. Redux和React-Redux的实现(一):Redux的实现和context

    react使用redux做状态管理,实现多个组件之间的信息共享,解决了父子组件.兄弟组件之间的复杂通信问题.vue有vuex,总之是一种flux的思想.react提供了react-redux这个库,一 ...

  8. Beta阶段版本控制报告

    版本控制代码及文档要求 在coding.net版本控制; 公开项目,教师.专家.其他同学可以不注册源代码.在此公布git地址. 报告beta阶段2周中,项目的版本控制情况,不包括未在coding.ne ...

  9. 通过反汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的

    实验一:通过反汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的 学号:20135114 姓名:王朝宪 注: 原创作品转载请注明出处   <Linux内核分析>MOOC课程http: ...

  10. 《Java学习笔记JDK8》学习总结

    chapter 6   继承与多态 6.1何谓继承 1.继承的定义:继承就是避免多个类间重复定义共同行为. 2.总结:教材中通过设计一款RPG游戏的部分代码向我们展示了“重复”程序代码的弊端,为了改进 ...