小渣飞、
2020-12-11 00:15
采纳率: 93.8%
浏览 5
已采纳

Java 中关于递归的问题?

如果当前路径是一个文件夹,那么它将重新调用本方法,但是如果这个文件夹下有多个文件夹呢?请问它们是怎么被遍历到的

@Test
    public void methodThree() {
        File dir = new File("/Users/jeffrey/Desktop/1");
        printSubFile(dir);
    }

    public static void printSubFile(File dir) {
        // 打印目录的子文件
        File[] file = dir.listFiles();

        if (file != null) {
            for (File f : file) {
                if (f.isDirectory()) {// 文件目录
                    printSubFile(f);
                } else {// 文件
                    System.out.println(f.getAbsolutePath());
                }

            }
        }
    }
  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • 北堂桓禧 2020-12-11 10:10
    已采纳

    方法调用就是压栈和弹栈,递归调用也是一样。以你的代码段为例,每次调用printSubFile就会记录执行点位然后压一个方法栈,然后在新的方法栈中循环。循环完了方法结束就会弹出当前方法栈回到上一个方法栈的执行点位(前面记录过),继续老的方法栈的循环。

    示例:假设/Users/jeffrey/Desktop/1下有2个文件夹DirA和DirB,DirA下有2个文件FileA1和FileA2。第一次进入printSubFile压一个方法栈(目录是/Users/jeffrey/Desktop/1),遍历到DirA发现是目录就会调用printSubFile-记录下当前执行点位(遍历到DirA了),并压一个新的方法栈(目录是/Users/jeffrey/Desktop/1/DirA)然后遍历DirA的文件,遍历结束即方法结束就会弹出当前方法栈,回来上一个printSubFile的执行点位继续遍历。

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • i__0o0__ 2020-12-11 09:47
            private void RemoveDirectory(string path)
            {
                //遍历当前目录下所有文件,删除
                foreach (string filePath in Directory.EnumerateFiles(path))
                {
                    File.Delete(filePath);
                }
    
                //遍历当前目录下所有文件夹,删除
                foreach (string directory in Directory.EnumerateDirectories(path))
                {
                    //因为不能删除非空的文件夹,所以递归调用RemoveDirectory,删除此文件夹
                    RemoveDirectory(directory);
                    
                }
    
               //清空文件夹后,删除此文件夹
               Directory.Delete(path);
                
            }
    评论
    解决 无用
    打赏 举报
  • 小渣飞、 2020-12-11 20:10

    感谢二楼回答,讲的很详细

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题