Java基础|递归算法删除文件夹及其子文件

import java.io.File;


/*问题描述:
 * 使用递归算法删除文件夹(文件夹下可能有N层文件或文件夹)
 * 
 * 解题思路:
 * 知识回顾:
 * <1>file.delete() 只可以删除文件或空文件夹;不可以删除非空文件夹
 * <2>如何删除非空文件夹呢?
 *    可以把非空文件夹里的 文件或者空的子文件删掉;
 *    对于非空的子文件夹,可以进入到里面,把它里面的东西删掉
 *    让它变成空的文件夹,再把它删掉即可。
 * 
 * */
public class Demo
{


	public static void main(String[] args)
	{
		File file = new File("e:\\aa");
		deleteFile(file);
		System.out.println("文件删除成功!");
	}




	
//封装文件删除方法
	//向方法传入的是一个File对象
	public static void deleteFile(File file)
	{
		if(file.isFile())//如果是文件,则直接删除
		{
			file.delete();
		}
		  /*如果是文件夹分两种情况处理
		   * <1>如果是空的文件夹,则可以直接删除
		   * <2>如果是非空的文件夹,则递归调用自身
		   *   可以清空该文件夹,使其变成空的文件夹。
		   *  最后再删除自身即可。
		   * 
		   * */
		else
		{
			/*知识积累:
			 * 判断是否为空文件夹的方法。
			 *   用文件夹类型的数组,获取该文件夹下的所有子文件或
			 *   子文件夹。若该数组的长度为0 或该数组为null.则表示
			 *   该文件夹为空的文件夹。则可以删除。
			 * 
			 * */
			File[] childFile = file.listFiles();
			if(childFile==null||childFile.length==0)//为空的文件夹,则直接删除
			{
				file.delete();
			}
			//不是空文件夹,则递归调用自身,使其成为空的文件夹
			else
			{
				//遍历递归调用
				for(int i=0;i<childFile.length;i++)
				{
					File child = childFile[i];
					deleteFile(child);
				}
			}
			//该文件夹清空了,则删除自身
			file.delete();		
		}
	}
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不甩锅的码农

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值