Java递归和非递归遍历文件夹

1.常用的递归遍历:

public void traverseFolderByRecursion(String path){
		File file=new File(path);
		if(file.exists()){
			File[] files=file.listFiles();
			for(File thisFile : files){
				if(thisFile.isDirectory()){
					traverseFolderByRecursion(thisFile.getAbsolutePath());
				}else{
					System.out.println(thisFile.getName());
				}
			}
		}else{
			System.out.println("该文件夹为空!");
		}
	}

 

2.使用非递归的方法来遍历文件夹:

/**
	 * 非递归遍历
	 */
	public void traverseFolder(String path){
		LinkedList<File> list = new LinkedList<File>();
		File file =new File(path);
		if(file.exists()){
			File[] files=file.listFiles();
			for(File thisFile :files){
				if(thisFile.isDirectory()){
					list.add(thisFile);
					continue;
				}
				System.out.println(thisFile.getName());
			}
		}else{
			System.out.println("该文件将夹为空!!!");
		}
		File tempFile;
		for(Iterator itr=list.iterator();itr.hasNext();){
			tempFile=list.removeFirst();
			for(File thisFile:tempFile.listFiles()){
				if(thisFile.isDirectory()){
					list.add(thisFile);
					continue;
				}
				System.out.println(thisFile.getName());
			}
		}
	}

 

已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页