zoukankan      html  css  js  c++  java
  • Java基础

    非递归方式

    public static void noRecursion(File dir){
            int fileNum=0,folderNum=0;
            LinkedList<File> list=new LinkedList<File>();
            if(dir.exists()){
                if (null==dir.listFiles()){
                    return;
                }
                list.addAll(Arrays.asList(dir.listFiles()));
                while(!list.isEmpty()){
                    File[] files = list.removeFirst().listFiles();
                    if(null==files){
                        continue;
                    }
                    for (File f:files) {
                        if (f.isDirectory()) {
                            System.out.println("文件夹:" + f.getAbsolutePath());
                            list.add(f);
                            folderNum++;
                        } else {
                            System.out.println("文件:" + f.getAbsolutePath());
                            fileNum++;
                        }
                    }
                }
            }else{
                System.out.println("文件不存在!");
            }
            System.out.println("文件夹数量:" + folderNum + ",文件数量:" + fileNum);
        }

    递归方式

     public static void showDir(File dir) {
            if(dir.exists()){
                //抽象路径名数组,这些路径名表示此抽象路径名表示的目录中的文件和目录。
                File[] files = dir.listFiles();
                if(null!=files){
                    for (int i = 0; i < files.length; i++) {
                        if (files[i].isDirectory()) {
                            showDir(files[i]);
                        } else {
                            System.out.println(files[i]);
                        }
                    }
                }
            }else{
                System.out.println("文件不存在!");
            }
        }

     性能比较

    public static void main(String[] args) {
            System.out.println("------------------------------------------递归开始--------------------------------------------------------");
            long start = System.currentTimeMillis();
            showDir(new File("D:\IDEAProject\helloMi"));
            long end = System.currentTimeMillis();
            long num1=end-start;
            System.out.println("---------------------递归结束-----------------------");
            
            System.out.println("-------------------- 非递归开始----------------------");
            start=System.currentTimeMillis();
            noRecursion(new File("D:\IDEAProject\helloMi"));
            end=System.currentTimeMillis();
            System.out.println("---------------------非递归结束----------------------");
            long num2=end-start;
            System.out.println("-------------------------递归用时:"+num1);
            System.out.println("-------------------------非递归用时:"+num2);
        }
    结果:
    -------------------------递归用时:18
    -------------------------非递归用时:20
  • 相关阅读:
    Markdown语法
    负载均衡、反向代理、CDN的概念
    IDEA远程调试
    跨域简介
    java命令:javac/java/javap
    尾递归实现斐波那契数列
    Java集合:框架
    volatile简介与原理
    乐观锁和悲观锁
    移动端布局的心得
  • 原文地址:https://www.cnblogs.com/isxiaoming/p/12436032.html
Copyright © 2011-2022 走看看