码迷,mamicode.com
首页 > 其他好文 > 详细

IO流-递归删除带内容的目录

时间:2017-08-15 22:54:55      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:rect   static   判断   print   direct   led   io流   目录   logs   

/*
 * 需求:递归删除带内容的目录
 * 
 * 目录:demo
 * ----------------------------------------------------------------------------------         
 *   具体的demo目录如下:
 *            demo\aaaa\a1.txt
 *            demo\aaaa\a2.txt
 *            demo\bbbb\b1.txt
 *            demo\bbbb\b2.txt
 *   具体的删除结果如下:(删除顺序:先删某文件夹下的文件,再删该文件)  
 *            a1.txt
 *            a2.txt
 *            aaaa
 *       
 *            b1.txt
 *            b2.txt
 *            bbbb
 *       
 *           demo
 *
 * -----------------------------------------------------------------------------------
 * 分析:
 * 		A:封装目录
 * 		B:获取该目录下的所有文件或者文件夹的File数组
 * 		C:遍历该File数组,得到每一个File对象
 * 		D:判断该File对象是否是文件夹
 * 			是:回到B
 * 			否:就删除
 */
   public class FileDeleteDemo {
	public static void main(String[] args) {
		// 封装目录
		File srcFolder = new File("demo");
		// 递归实现
		deleteFolder(srcFolder);
	}
        
	private static void deleteFolder(File srcFolder) {
		// 获取该目录下的所有文件或者文件夹的File数组
		File[] fileArray = srcFolder.listFiles();
		 if (fileArray != null) {
			// 遍历该File数组,得到每一个File对象
			for (File file : fileArray) {
				// 判断该File对象是否是文件夹
				if (file.isDirectory()) {
                                 //回到B,继续执行(递归)
				   deleteFolder(file);
				} else {
                                 //打印删除了的文件
				     System.out.println(file.getName() + "---" +file.delete());
			        }
			}
               //打印删除的文件夹(先删除该文件夹下的文件,再删除文件夹)
		System.out.println(srcFolder.getName() + "---" + srcFolder.delete());
	       }
	}
}

  

IO流-递归删除带内容的目录

标签:rect   static   判断   print   direct   led   io流   目录   logs   

原文地址:http://www.cnblogs.com/yuefeng123/p/7367872.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!