具有递归方法的ArrayList

时间:2014-01-12 15:53:21

标签: java arraylist jpanel

我是使用Swing的新手 - 我有一个递归方法,它遍历硬盘上的目录并且当前打印出音乐曲目 - 我想将曲目添加到数组列表中,以便我可以发送完整的列表到JPanel并在那里显示...当为每个文件夹递归调用该方法时,如何停止清除数组列表?感谢

2 个答案:

答案 0 :(得分:0)

我不确定我是否理解您的代码,所以我会从头开始重新启动,给你一些伪代码:

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);
        }
    }
}

答案 1 :(得分:0)

请尝试以下代码

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));
     }
  }
}