Java递归第二篇

本文介绍了一种使用递归方法在Java中彻底删除文件夹及其所有子文件的方法,通过遍历文件夹内的所有子文件和子文件夹并逐个删除,最后删除空文件夹,确保文件系统整洁。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

上一篇我们用递归实现了计算文件夹的大小,这一次我们用递归来删除文件夹(包含该文件夹下的文件),删掉的文件夹不会在回收站里。

代码如下:
package day01;

import java.io.File;

public class DeleteFiles {

	public static void main(String[] args) {
		File dir = FileLength.getDir();//FileLength类在我博客里的递归第一篇里有
		deleteFiles(dir);		
	}
	public static void deleteFiles(File dir) {
		//获取dir目录下所有的文件及文件夹
		File[] subFiles = dir.listFiles();
		//遍历dir目录
		for (File subfile : subFiles) {
			if (subfile.isFile()) {
				subfile.delete();
			}else {
				deleteFiles(subfile);
			}
		}
		dir.delete();//这一步特别关键,因为这一步会删除掉空文件夹,不加这一步会保留空文件夹。
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值