递归算法删除文件夹示例

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

    原文作者:递归算法
    原文地址: https://blog.csdn.net/BiLaHePan/article/details/51569629
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞