1、題目
對指定目錄進(jìn)行所有內(nèi)容的列出(包含子目錄中的內(nèi)容),也可以理解為對目錄進(jìn)行深度遍歷。
2、解題思想
從電腦中獲取文件目錄,建立函數(shù)對其遍歷,在這個函數(shù)中需要對該目錄中的每個文件進(jìn)行判斷,如果文件還是目錄,則調(diào)用函數(shù)本身繼續(xù)對其進(jìn)行遍歷,如果文件不是目錄,則直接輸出文件名。為了加強(qiáng)顯示的效果,我們還可以建立一個getSpace函數(shù),對其進(jìn)行縮進(jìn)。
需要注意的是,不要直接遍歷C盤的內(nèi)容,其目錄層次太深,含有太多的系統(tǒng)級文件,容易返回為空,導(dǎo)致空指針異常的發(fā)生,也不要直接遍歷D盤,因為只要其含有隱藏的系統(tǒng)卷標(biāo)目錄,也會造成空指針異常的發(fā)生。
3、Java代碼
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
import java.io.File; public class DepthTraversal { public static void main(String[] args) { File dir = new File( "d:\\BaiduYunDownload" ); listAll(dir, 0 ); } public static void listAll(File dir, int level) { System.out.println(getSpace(level) + dir.getName()); level++; //每調(diào)用一次,level加1 File[] files = dir.listFiles(); //獲取指定目錄下當(dāng)前的所有文件夾或者文件對象 for ( int x = 0 ; x < files.length; x++) { //循環(huán)遍歷 if (files[x].isDirectory()) { //如果是目錄,繼續(xù)調(diào)用listAll函數(shù) listAll(files[x], level); } else { //否則,直接輸出文件名 System.out.println(getSpace(level) + files[x].getName()); } } } private static String getSpace( int level) { //輸出空格,加強(qiáng)顯示效果 StringBuilder sb = new StringBuilder(); sb.append( "|--" ); for ( int x = 0 ; x < level; x++) { sb.insert( 0 , "| " ); } return sb.toString(); } } |
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
原文鏈接:http://blog.csdn.net/qq_35246620/article/details/53155892