java - 递归方法在返回值后继续?

标签 java recursion

我正在编写一个快速的 Java 递归方法,给定一个根文件夹和文件名,在您的文件中搜索所述文件名。

import Java.io.File;

public static String searchForFile(File currentFolder, String filename)
{
    try
    {
        File[] path = currentFolder.listFiles();

        for (int i = 0; i < path.length; i++)
        {
            if (path[i].isDirectory())
            {
                System.out.println("Directory: " + path[i].toString());
                searchForFile(path[i], filename);
            }
            else
            {
                System.out.println("File: " + path[i].toString());

                if(path[i].getName().equals(filename))
                {
                    System.out.println("Your file has been found!";
                    return path[i].toString();
                }
            }
        }
    }
    catch (Exception e)
    {
        e.printStackTrace();
    }

    return null; // Omitting this line yields compiling errors, not sure why?
}

public static void main(String[] args)
{
    System.out.println("Hello, enter the root folder and file name.");
    String rootFolder = "Desktop";
    String fileName = "Hello.txt";

    File f = new File("C:\\Users\\Me\\" + rootFolder);
    searchForFile(f, fileName);

}

程序本身在技术上是可行的,但是 searchForFile() 即使在找到所请求的文件之后也会继续迭代。例如,我会得到如下输出:

File: C:\Users\Me\Desktop\My Stuff\NotHello.txt
**File: C:\Users\Me\Desktop\My Stuff\Hello.txt**

Your file has been found!

File: C:\Users\Me\Desktop\My Stuff\AlsoNotHello.txt
File: C:\Users\Me\Desktop\My Stuff\StillNotHello.txt
File: C:\Users\Me\Desktop\My Stuff\WhyIsThisMethodStillRunning.txt

一段时间以来,我一直在摸不着头脑。我以为 return 总是退出方法,那么为什么即使在返回值后递归仍在继续?我还没有发现任何类似的问题,所以任何帮助将不胜感激!

(此外,如果未找到所请求的文件,我该如何编辑该方法以使其返回空白 "" 字符串?)

最佳答案

当您找到文件时,您将从最内层的调用返回。但是当你扫描一个目录时,你并没有使用返回值。

改变这个:

searchForFile(path[i], filename);

到:

String result = searchForFile(path[i], filename);
if (result != null) {
    return result;
}

方法底部的 return null; 在那里,因为所有方法都需要返回一个值。不管文件是否找到。如果在当前目录(或其子目录之一)中未找到该文件,您可以返回 null; 以指示未找到该文件。

附带建议:在 Java 8 中使用 Optional 而不是 null

关于java - 递归方法在返回值后继续?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43712687/

相关文章:

java - 模拟 servlet,我该如何正确地模拟它?

javascript - 等待递归函数时获取未定义的结果

java - 递归函数StackOverflowError

java - Spring 数据 REST : "no String-argument constructor/factory method to deserialize from String value"

java - Eclipse 将插件导入为源项目,但它不包含 src 文件夹

递归查找数组中最大元素的巧妙方法

java - Java 中使用 BigInteger 计算 50 阶乘

typescript - 递归函数的类型

java - 如何显示黑底白字?

java - Java中的基本类型decimal - 用户入口