java 文件 递归_Java之File与递归

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);

}

}

}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值