2013-02-19 43 views
2

有人可以帮我解决我的问题。我有一个函数,用于检查文件是否存在于特定路径中。该函数检查文件名是否匹配,路径是否匹配(具有特定名称的文件可能存在于多个位置)。请在下面找到我的代码。退货声明不起作用

memberPath是一个包含相对路径的静态变量。 file_Path是一个静态变量,当找到匹配项时它会被更新。

我的问题是该函数找到匹配,但它突然出现for循环返回语句,但回到for循环。有人可以帮助我修复我的代码,以便一旦找到匹配,它将返回到呼叫位置。

public static String traverse(String path, String filename) { 
     String filePath = null; 
     File root = new File(path); 
     File[] list = root.listFiles(); 

     for (File f : list) { 
      if (f.isDirectory()) { 
       traverse(f.getAbsolutePath(), filename); 
      } else if (f.getName().equalsIgnoreCase(filename) && f.getAbsolutePath().endsWith(memberPath)) { 
       filePath = f.getAbsolutePath(); 
       file_Path = filePath; 
       break ; 
       } 
     } 
     return filePath; 
} 
+1

这就是递归。你期望会发生什么? – 2013-02-19 08:34:14

+2

为什么不,而不是立即返回? – 2013-02-19 08:36:35

+0

@RohitJain:但是你能告诉我应该添加什么,以便它返回到呼叫位置 – user1688404 2013-02-19 08:36:50

回答

6

地址:

return traverse(f.getAbsolutePath(), filename); 

回到你这个电话获得的价值。

正如指出的那样 - 您可以返回值而不是中断。

+0

你是否指file_Path = filePath;而不是休息;添加返回遍历(f.getAbsolutePath(),filename); – user1688404 2013-02-19 08:45:38

+0

是的。而不是打破只是返回filePath。这不是什么大不了的事情,但是它更好,因为您已经拥有了价值,并且可以将其退回。 – BobTheBuilder 2013-02-19 08:51:28

+0

是否这样?公共静态字符串遍历(字符串路径,字符串文件名){ String filePath = null; File root = new File(path); File [] list = root.listFiles(); (f.isDirectory()){ 遍历(f.getAbsolutePath(),filename);如果(f.isDirectory()){ (f.getName()。equalsIgnoreCase(filename)..){ filePath = f.getAbsolutePath(); file_Path = filePath; 返回遍历(f.getAbsolutePath(),filename);; } } return filePath; ( } – user1688404 2013-02-19 08:58:43

3

递归方式的工作方式是该函数自己调用。所以,当你的函数return S,它可以追溯到到for循环,因为它很可能是外部函数调用它从下面的线

if (f.isDirectory()) { 
      traverse(f.getAbsolutePath(), filename); 

既然是这样的话,你需要(调用它的一个)按照baraky的解释在这里添加返回值,否则你将失去内部函数派生的答案。

1

正如指出的baraky,KARTHIK和JanDvorak,更新的代码是:

public String traverse(String path, String filename) { 
     String filePath = null; 
     File root = new File(path); 
     File[] list = root.listFiles(); 

     for (File f : list) { 
      if (f.isDirectory()) { 
       return traverse(f.getAbsolutePath(), filename); 
      } else if (f.getName().equalsIgnoreCase(filename) 
        && f.getAbsolutePath().endsWith(memberPath)) { 
       filePath = f.getAbsolutePath(); 
       file_Path = filePath; 
       return filePath; 

       } 
     }  
     return filePath; 
    } 

谢谢你们!