簡體   English   中英

具有遞歸方法的ArrayList

[英]ArrayList with recursive method

我是使用Swing的新手-我有一種遞歸方法,該方法可在硬盤驅動器上的目錄上進行迭代,並當前打印出音樂曲目-我想將曲目添加到數組列表中,以便將完整列表發送到JPanel並在此處顯示...當遞歸地為每個文件夾調用該方法時,如何停止清除數組列表? 謝謝

我不確定我是否理解您的代碼,因此我將通過提供一些偽代碼從頭開始:

private List<File> getAllAudioFiles(File folder) {
    List<File> result = new ArrayList<>(); 
    // you want a single list. There should be no other list creation in the algorithm.
    addAllAudioFiles(folder, result);
    return result;
}

private void addAllAudioFiles(File folder, List<File> result) {
    for (File file : folder.listFiles()) {
        if (file.isDirectory()) {
            // call this method recursively, to add all the audio files in the subfolder
            // to the SAME list
            addAllAudioFiles(file, result); 
        }
        else if (isAudioFile(file)) {
            result.add(file);
        }
    }
}

試試下面的代碼

public class MusicGetter {

ArrayList<String> tlist = new ArrayList<>();

MusicGetter(String c) {
    addToList(c);
}

private void addToList(String s) {
    File root = new File(s);
    File[] files = root.listFiles();
    for (File f : files) {
        String str = f.getPath();
        if (str.endsWith(".mp3") || str.endsWith(".wav") || str.endsWith(".flac") || str.endsWith(".m4a") || str.endsWith(".ogg") || str.endsWith(".wma")) {
            tlist.add(str);
        }
        if (f.isDirectory()) {
            addToList(f.getPath().toString());
        }
    }
}

public static void main(String[] args) {
    MusicGetter mg = new MusicGetter("E:\\audios");
    for (int i = 0; i < mg.tlist.size(); i++) {
        System.out.println(mg.tlist.get(i));
     }
  }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM