用递归方式来实现删除硬盘的文件或目录(空文件夹)

首先要找到递归的入口及出口,这点很重要,成败在此,呵呵!

代码实现:

  1. import java.io.File ;
  2. class RecursionDeleteFileDemo //利用递归 删除 文件或目录 操作
  3. {
  4. public static void deleteFiles(File file)
  5. {
  6. //递归出口
  7. //判断目前文件,如果是文件 或 是一个空的文件夹,则删除
  8. if(file.isFile() || file.list().length ==  0)
  9. {
  10. file.delete() ;
  11. }
  12. else
  13. {
  14. File[] files = file.listFiles() ;
  15. for(File f : files)
  16. {
  17. //递归入口
  18. deleteFiles(f) ;
  19. f.delete() ;
  20. }
  21. }
  22. }
  23. }
  24. public class RecursionDeleteFile
  25. {
  26. public static void main(String[] args)
  27. {
  28. File file = new File("E:/abc") ;
  29. RecursionDeleteFileDemo.deleteFiles (file) ;
  30. }
  31. }

File[] files = file.listFiles() ;    

返回: 抽象路径名数组,这些路径名表示此抽象路径名表示的目录中的文件和目录

测试类程序:RecursionDeleteFileDemoTest.java

  1. package com.junit3_8;
  2. import java.io.File;
  3. import java.io.IOException;
  4. import junit.framework.Assert;
  5. import junit.framework.TestCase;
  6. public class RecursionDeleteFileDemoTest extends TestCase{
  7. //测试只有一个文件的目录
  8. public void testDeleteFiles()
  9. {
  10. File file = null ;
  11. try {
  12. file = new File("a.txt");
  13. file.createNewFile();
  14. RecursionDeleteFileDemo.deleteFiles(file);
  15. } catch (IOException e) {
  16. Assert.fail();
  17. }
  18. boolean result ;
  19. //exists()判断该文件或目录是否存在
  20. result = file.exists();//false
  21. Assert.assertFalse(result);
  22. }
  23. /**
  24. * 测试生成多层目录,目录结构如下
  25. *
  26. *      root
  27. *       /\
  28. *      /  \
  29. * child1   child2
  30. *
  31. */
  32. public void testDeleteFiles2()
  33. {
  34. File directory = null ;
  35. try {
  36. directory = new File("root");//构造一个子目录
  37. directory.mkdir();//建立一个新的根目录
  38. File file0 = new File(directory,"xx.txt");
  39. file0.createNewFile();
  40. //在root目录下生成两个子目录
  41. File file1 = new File(directory,"child1");
  42. File file2 = new File(directory,"child2");
  43. file1.mkdir();
  44. file2.mkdir();
  45. //分别在file3和file4目录下建一个文本文件
  46. File file3 = new File(file1,"a.txt");
  47. File file4 = new File(file2,"b.txt");
  48. file3.createNewFile();
  49. file4.createNewFile();
  50. RecursionDeleteFileDemo.deleteFiles(directory);
  51. }
  52. catch(Exception e)
  53. {
  54. Assert.fail();
  55. }
  56. Assert.assertNotNull(directory);
  57. String[] str = directory.list();
  58. Assert.assertEquals(0, str.length);
  59. directory.delete();//删除根目录
  60. }
  61. }

JUnit 3.8 演示递归删除文件目录的 测试类程序 .的更多相关文章

  1. myBatis执行测试批量删除,出现测试类正常显示,但数据库数据没变

    一般在测试myBatis运行正常,但数据库数据不变时,有可能是SQL语句有问题,检查SQL语句没问题,但数据库依然没变,就说明myBatis方法执行后并未提交到数据库,可尝试在测试类添加   sess ...

  2. Java递归删除文件目录的方法

    public static void delDir(String path){ File dir=new File(path); if(dir.exists()){ File[] tmp=dir.li ...

  3. java基础 File 递归删除文件夹中所有文件文件夹 目录(包含子目录)下的.java文件复制到e:/abc文件夹中, 并统计java文件的个数

    File 递归删除文件夹中所有文件文件夹 package com.swift.kuozhan; import java.io.File; import java.util.Scanner; /*键盘录 ...

  4. python dict clear只能删除一层,不能够递归删除。

    void PyDict_Clear(PyObject *op) { dictobject *mp; dictentry *ep, *table; int table_is_malloced; Py_s ...

  5. 【File】递归删除文件夹中子级文件/夹,并删除文件夹

    今天有这样一个需求,需要删除某一个文件夹,但是文件夹中还有子级的文件 或者还可能会有文件夹在里面,所以就需要使用一个简单的递归才能将文件夹删除成功,包括文件夹中的子级文件/夹.!!! 其实很简单,就一 ...

  6. php 递归创建目录、递归删除非空目录、迭代创建目录

    递归创建目录 方法一 function mk_dir($path){ if(is_dir($path)){ //参数本身是一个目录 return true; } if(is_dir(dirname($ ...

  7. Linux递归删除文件命令

    Linux递归删除文件命令 find . -name "*.log.*" -exec ls {} \; find . -name "*.log.*" -exec ...

  8. linux系统下,递归删除.svn文件

    linux系统下,递归删除.svn文件 SVNLinux 进入要删除的目录,执行下面的命令就可以啦. find . -name "*.svn"  | xargs rm -rf

  9. SVN莫名出错,网上找遍无果,递归删除当前目录下所有.svn文件名

    哎,太深刻的教训. 原来以前其它目录里有.SVN目录 ,而此SVN目录COPY到真正的SVN工作目录之后,会将有用的.SVN目录覆盖. 那么一样,显然,CI,UPDATE,CO之间的命令全部异常... ...

随机推荐

  1. [P1768]天路(分数规划+SPFA判负环)

    题目描述 “那是一条神奇的天路诶~,把第一个神犇送上天堂~”,XDM先生唱着这首“亲切”的歌曲,一道猥琐题目的灵感在脑中出现了. 和C_SUNSHINE大神商量后,这道猥琐的题目终于出现在本次试题上了 ...

  2. [BZOJ 4071] 巴邻旁之桥

    Link: BZOJ 4071传送门 Solution: 首先算出能提前算的贡献 $K=1$:肯定选中间的点,小学数学 $K=2$:对于每对$(x,y)$一定选离$(x+y)/2$近的桥 也就是说将$ ...

  3. POJ1716 贪心

    题目大意:在[0,10000]上给出n个区间,要求在区间选整数点,每个区间至少包含两个点,问至少要几个点.题目保证有解决方案. 题目分析: 我们做过在区间上至少包含一个点的题目.类似的方法,我们先排序 ...

  4. 【多重背包小小的优化(。・∀・)ノ゙】BZOJ1531-[POI2005]Bank notes

    [题目大意] Byteotian Bit Bank (BBB) 拥有一套先进的货币系统,这个系统一共有n种面值的硬币,面值分别为b1, b2,..., bn. 但是每种硬币有数量限制,现在我们想要凑出 ...

  5. hdu 4790 Just Random

    思路:对于a<=x<=b,c<=y<=d,满足条件的结果为ans=f(b,d)-f(b,c-1)-f(a-1,d)+f(a-1,c-1). 而函数f(a,b)是计算0<= ...

  6. How to open a web site with the default web browser in a NEW window

    http://delphi.about.com/cs/adptips2004/a/bltip0504_4.htm When using ShellExecute (as explained in th ...

  7. 使用cwrsync做服务器文件夹同步

    首先要下载cwRsync的服务端和客户端软件(4.05免费版),下载地址如下: https://www.itefix.no/i2/cwrsync 具体的配置过程和遇到的问题可参考: http://ww ...

  8. mount umont

    如果想在运行的Linux下访问其它文件系统中的资源的话,就要用mount命令来实现. 2.      mount的基本用法是?格式:mount [-参数] [设备名称] [挂载点] 其中常用的参数有: ...

  9. WebKit 在 Windows 平台下编译小结

    虽然WebKit 已经越来越多的被广大程序员接受,但其编译过程却非常之痛苦.下面将我编译WebKit 代码的经验与大家分享. 1) 获取WebKit 源代码 WebKit 源代码是使用Subversi ...

  10. 对于Ian的访谈,不少关于GAN的内容

    文章链接如下: http://3g.163.com/dy/article/DD1GBSLF0511ABV6.html 里面提到胶囊网络,我找了这篇文章看了下: https://blog.csdn.ne ...