java如何实现显示目录文件列表和删除目录功能,java 目录是否存在

小编给大家分享一下java如何实现显示目录文件列表和删除目录功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!以d:\a目录为例,假设D:\a目录内的结构如下:d。

小编给大家分享一下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如何实现显示目录文件列表和删除目录功能相关内容。