zoukankan      html  css  js  c++  java
  • Java非递归的方式获取目录中所有文件(包括目录)

    零、思路解析

    对于给出的文件查看其下面的所有目录,将这个目录下的所有目录放入待遍历的目录集合中,每次取出该集合中的目录遍历,如果是目录再次放入该目录中进行遍历。

    一、代码

        /**
         * 非递归的方式获取目录中的所有文件<br>
         * 此方法获取的路径未按照目录->文件方式排列
         *
         * @param dirPath 目录路径
         * @return 指定目录下所有文件和目录的集合
         */
        public static List<File> listAllFile(String dirPath) {
            LinkedList<File> allFiles = new LinkedList<>();
            if ("".equals(dirPath) || null == dirPath) {
                return allFiles;
            }
            File file = new File(dirPath);
            allFiles.add(file);//添加自己
            if (file.isFile()) {
                return allFiles;
            }
    
            File[] fileList = file.listFiles();
            if (fileList == null || fileList.length == 0) {
                return allFiles;
            }
            //将第一次获取到的文件和目录放入总集合中
            allFiles.addAll(Arrays.asList(fileList));
    
            //声明存放目录的集合
            LinkedList<File> dirCheckList = new LinkedList<>();
            //处理第一层目录
    
            for (File curFile : fileList) {
                if (curFile.isDirectory()) {
                    dirCheckList.add(curFile);
                }
            }
    
            while (!dirCheckList.isEmpty()) {
                File removeDir = dirCheckList.removeFirst();//移除首位的目录
                File[] removeDirFileList = removeDir.listFiles();
                if (removeDirFileList == null) {
                    continue;
                }
                //将找出的所有的文件和目录加入到总集合中
                allFiles.addAll(Arrays.asList(removeDirFileList));
                for (File curFile : removeDirFileList) {
                    if (curFile.isDirectory()) {
                        dirCheckList.add(curFile);
                    }
                }
            }
            return allFiles;
        }
  • 相关阅读:
    用OpenGL简单编写的一个最简单贪吃蛇游戏
    Python lambda map filter reduce
    Hadoop Python MapReduce
    Python faker生成数据
    Pandas数据清洗
    PySpark与jupyer notebook
    虚拟机与宿主机网络共享
    集合覆盖问题与贪婪算法
    最快路径与狄克斯特拉
    最短路径问题与广度优先搜索
  • 原文地址:https://www.cnblogs.com/LiuChunfu/p/6822960.html
Copyright © 2011-2022 走看看