我正在尝试在根目录及其子目录中查找文件。
Step1-在指定路径中查找目录。Step2-如果找到上述目录,请在其中一个子目录中查找文件。
为此,我使用以下递归搜索的代码片段。现在,这里的问题是,当递归满足我的上述两个要求时,我如何摆脱递归......?
boolean bFileFound = false;
File fileFound = null;
private void findFile( File aFile, String sDir ){
String filePath = aFile.getAbsolutePath();
if( aFile.isFile() && filePath.contains( sDir ) ){
if( aFile.getName().contains( "test2.adv")){
Log.d(TAG, "[FILE] " + aFile.getName() );
fileFound = aFile;
bFileFound = true;
}
// return true;
}else if( aFile.isDirectory() ){
String sDirName = aFile.getName();
Log.d(TAG, "[DIR] " + sDirName );
if( sDirName.contains( sDir ) ){
Log.d( TAG, "Found the directory..& Absolute Path = " + aFile.getAbsolutePath());
sDir = sDirName;
}
File[] listFiles = aFile.listFiles();
if( listFiles != null ){
for( int i = 0; i < listFiles.length; i++ ){
if(bFileFound)
return;
findFile( listFiles[ i ], sDir );
}
}else{
Log.d( TAG, " [ACCESS DENIED]" );
}
}
// return null;
}
谢谢, DK