遍历目录实现删除,取得大小及深度
2008-01-05 20:10:39 来源:WEB开发网 import java.io.*;
import java.util.*;
public class ManageContent {
PRivate int dir_deep=0;
private int dir_size = 0;
private int sourcepath_deep; //输入路径相对于根目录的深度
private Hashtable ht=new Hashtable(); //储存输入路径下的所有子目录,及其相对于根目录的深度keys=(String)dirPath,values=(Integer)dirDeep
public synchronized int getSize(String dir_path) throws FileNotFoundException {
File dir = new File(dir_path);
if (!dir.exists()) {
throw new FileNotFoundException();
}
if (!dir.isDirectory()) {
dir_size = (int) dir.length();
}
else {
File[] fe = dir.listFiles();
for (int i = 0; i < fe.length; i++) {
if (fe[i].isDirectory()) {
getSize(fe[i].toString());
}
else {
dir_size += fe[i].length();
}
}
}
return dir_size;
}
public synchronized void deleteFiles(String dir_path) throws FileNotFoundException {
File file = new File(dir_path);
if (!file.exists()) {
throw new FileNotFoundException();
}
if (file.isDirectory()) {
File[] fe = file.listFiles();
for (int i = 0; i < fe.length; i++) {
deleteFiles(fe[i].toString());
fe[i].delete(); //删除已经是空的子目录
}
}
file.delete(); //删除总目录
}
进入讨论组讨论。
private void allDeep(File file){
File[] fe = file.listFiles();
for (int i = 0; i < fe.length; i++) {
if (fe[i].isDirectory()) {
allDeep(fe[i]); //取得其所有子目录的深度
ht.put(fe[i].toString(),new Integer(count(fe[i].toString()) - sourcepath_deep));
赞助商链接