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
本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
原文地址: https://blog.csdn.net/BiLaHePan/article/details/51569629
本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。