源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Java编程获取文件列表及子文件目录的方法(非递归)

  • 时间:2020-05-02 22:01 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Java编程获取文件列表及子文件目录的方法(非递归)
废话不谈,直接进入正题,理解见代码注释。
// 非递归
  public List<String> scanFiles(String path) {
    List<String>filePaths = new ArrayList<String>();
    LinkedList<File> list = new LinkedList<File>();
    File dir = new File(path);
    File[] file = dir.listFiles();

    for (int i = 0; i < file.length; i++) {
      if (file[i].isDirectory()) {
        // 把第一层的目录,全部放入链表
        list.add(file[i]);
      }
      filePaths.add(file[i].getAbsolutePath());
    }
    // 循环遍历链表
    while (!list.isEmpty()) {
      // 把链表的第一个记录删除
      File tmp = list.removeFirst();
      // 如果删除的目录是一个路径的话
      if (tmp.isDirectory()) {
        // 列出这个目录下的文件到数组中
        file = tmp.listFiles();
        if (file == null) {// 空目录
          continue;
        }
        // 遍历文件数组
        for (int i = 0; i < file.length; ++i) {
          if (file[i].isDirectory()) {
            // 如果遍历到的是目录,则将继续被加入链表
            list.add(file[i]);
          }
          filePaths.add(file[i].getAbsolutePath());
        }
      }
    }
    return filePaths;
  }
以上就是本文关于Java编程获取文件列表及子文件目录的方法(非递归)的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:[url=http://www.1sucai.cn/article/126642.htm]Java编程子类能否重写父类的静态方法探索[/url]、[url=http://www.1sucai.cn/article/126552.htm]java编程枚举类型那些事!枚举类型定义和重写枚举的方法[/url]等,如有不足之处,欢迎留言参考。感谢朋友们对本站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部