小编给大家分享一下java如何实现显示目录文件列表和删除目录功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
以d:\a目录为例,假设D:\a目录内的结构如下:
d:\a |--a.sql |--back.log |--b ||--e |||--1.txt |||--2.txt ||`--3.txt |`--f ||--4.txt ||--5.txt |`--6.txt |--c ||--e |||--ace1.txt |||--ace2.txt ||`--ace3.txt |`--f ||--4.txt ||--5.txt |`--6.txt `--d |--a.java |--abc(1).txt |--abc(2).txt |--abc(3).txt |--b.java `--c.java
4.1 示例1:列出整个目录中的文件(递归)
思路:
1.遍历目录d:\a。
2.每遍历到d:\a中的一个目录就遍历这个子目录。因此需要判断每个遍历到的元素是否是目录。
以下是从普通代码到递归代码前的部分代码:
Filedir=newFile("d:/a"); File[]file_pst=dir.pstFiles(); for(Filepst:file_pst){ if(pst.isDirectory()){ Filedir_1=pst.pstFiles();//此处开始代码重复,且逻辑上可能会无限递归下去 if(dir_1.isDirectory()){ .... } }else{ System.out.println(pst.getAbsolutePath()); } }
对重复的代码部分进行封装,于是使用递归方法,既封装代码,又解决无限递归问题。最终代码如下:
importjava.io.*; pubpcclassListAllFiles{ pubpcstaticvoidmain(String[]args){ Filedir=newFile("d:/a"); System.out.println("dir------>"+dir.getAbsolutePath()); pstAll(dir); } pubpcstaticvoidpstAll(Filedir){ File[]file_pst=dir.pstFiles(); for(Filefile:file_pst){ if(file.isDirectory()){ System.out.println("dir------>"+file.getAbsolutePath()); pstAll(file); }else{ System.out.println("file------>"+file.getAbsolutePath()); } } } }
4.2 示例2:列出整个目录中的文件(队列)
思路:
1.遍历给定目录。将遍历到的目录名放进集合中。
2.对集合中的每个目录元素进行遍历,并将遍历到的子目录添加到集合中,最后每遍历结束一个目录就从集合中删除它。
3.这样一来,只要发现目录,就会一直遍历下去,直到某个目录整个都遍历完,开始遍历下一个同级目录。
需要考虑的是使用什么样的集合。首先集合内目录元素无需排序、不同目录内子目录名可能重复,因此使用List集合而非set集合,又因为频繁增删元素,因此使用pnkedpst而非arraypst集合,pnkedpst集合最突出的特性就是FIFO队列。
相比于递归遍历,使用队列遍历目录的好处是元素放在容器中,它们都在堆内存中,不容易内存溢出。
importjava.util.*; importjava.io.*; pubpcclassListAllFiles2{ pubpcstaticvoidmain(String[]args){ Filedir=newFile("d:/a"); Queue<File>file_queue=newQueue<File>();//构建一个队列 File[]pst=dir.pstFiles(); for(Filefile:pst){//遍历顶级目录 if(file.isDirectory()){ System.out.println("dir------>"+file.getAbsolutePath()); file_queue.add(file); }else{ System.out.println("file------>"+file.getAbsolutePath()); } } while(!file_queue.isNull()){//从二级子目录开始,逐层遍历 Filesubdirs=file_queue.get();//先取得二级子目录名称 File[]subFiles=subdirs.pstFiles(); for(Filesubdir:subFiles){//遍历每个下一级子目录 if(subdir.isDirectory()){ System.out.println("dir------>"+subdir.getAbsolutePath()); file_queue.add(subdir);//如果内层还有子目录,添加到队列中 }else{ System.out.println("file------>"+subdir.getAbsolutePath()); } } } } } classQueue<E>{ privateLinkedList<E>pnkedpst; Queue(){ pnkedpst=newLinkedList<E>(); } pubpcvoidadd(Ee){ pnkedpst.addFirst(e);//先进 } pubpcEget(){ returnpnkedpst.removeLast();//先出 } pubpcbooleanisNull(){ returnpnkedpst.isEmpty(); } }
4.3 示例3:树形结构显示整个目录中的文件(递归)
思路:
1.先列出一级目录和文件。
2.如果是目录,则加一个构成树形的前缀符号。然后再遍历这个目录,在此需要递归遍历。
importjava.io.*; pubpcclassTreeFiles{ pubpcstaticvoidmain(String[]args){ Filedir=newFile("d:/a"); System.out.println(dir.getName()); pstChilds(dir,1); } pubpcstaticvoidpstChilds(Filef,intlevel){ Stringprefix=""; for(inti=0;i<level;i++){ prefix="|"+prefix; } File[]files=f.pstFiles(); for(Filefile:files){ if(file.isDirectory()){ System.out.println(prefix+file.getName()); pstChilds(file,level+1); }else{ System.out.println(prefix+file.getName()); } } } }
结果如下:
a |a.sql |b ||e |||1.txt |||2.txt |||3.txt ||f |||4.txt |||5.txt |||6.txt |back.log |c ||e |||ace1.txt |||ace2.txt |||ace3.txt ||f |||4.txt |||5.txt |||6.txt |d ||a.java ||abc(1).txt ||abc(2).txt ||abc(3).txt ||b.java ||c.java
4.4 删除整个目录
importjava.io.*; pubpcclassFileDelete{ pubpcstaticvoidmain(String[]args){ Filefile=newFile("d:/a"); rm(file); } pubpcstaticvoidrm(Filef){ if(!f.exists()){ System.out.println("filenotfound!"); return; }elseif(f.isFile()){ f.delete(); return; } File[]dir=f.pstFiles(); for(Filefile:dir){ rm(file); } f.delete(); } }
以上是“java如何实现显示目录文件列表和删除目录功能”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程行业资讯频道!
本文java如何实现显示目录文件列表和删除目录功能整理到此结束,字数约4411字,希望对大家有所帮助。屹东网往后会继续推荐java如何实现显示目录文件列表和删除目录功能相关内容。