在java中对文件夹的拷贝和删除

在java中对文件与文件目录的操作主要集中在java.io包,但是对于文件夹的操作还没有可用的直接处理方法。
对文件的操作最好的办法就是递归,很多人一听递归就放弃了,其实递归是很简单的,我先从递归设计的基本思想入手:
递归算法设计的基本思想是:对于一个复杂的问题,把原问题分解为若干个相对简单类同的子问题,继续下去直到子问题简单到能够直接求解,也就是说到了递推的 出口,这样原问题就有递推得解。
关键要抓住的是:
(1)递归出口
(2)地推逐步向出口逼近
只要把基本思想和关键的抓住,递归运算会和我们写Hello World一样的简单。
文件夹删除操作:
//originalFile源文件夹
public static void referDeleteFile(File originalFile) {
File filelist[] = originalFile.listFiles(); //获得文件夹的集合操作
for (File file : filelist) { //遍历
if (file.isDirectory()) { //判断是否是目录
referDeleteFile(file); //递归
} else {
file.delete(); //当不是目录时删除文件
}
}
originalFile.delete(); // 删除当前目录
}
文件夹拷贝操作:
//originalDir 源路径
//aimDir 目标路径
public static void referCopyFile(String originalDir, String aimDir) {
File originalFile = new File(originalDir); //实例化源文件
File filelist[] = originalFile.listFiles();//获得文件集合
for (File file : filelist) { //遍历
if (file.isDirectory()) {//判断是否是文件夹
new File(aimDir + File.separator + file.getName()).mkdirs();//在目标路径上创建目录
referCopyFile(originalDir + File.separator + file.getName(),//递归
aimDir + File.separator + file.getName());
} else {
if (file.isFile()) { //判断文件是否真实存在
BufferedInputStream bis = null;
FileInputStream in = null;
BufferedOutputStream bos = null;
FileOutputStream out = null;
try {
in = new FileInputStream(file);
bis = new BufferedInputStream(in);
out = new FileOutputStream(new File(aimDir
+ File.separator + file.getName()));
bos = new BufferedOutputStream(out);
byte[] b = new byte[1024 * 10];
int len;
while ((len = bis.read(b)) != -1) {
bos.write(b, 0, len);
}
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
try {
bos.flush();
bos.close();
out.close();
bis.close();
in.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
} else {
System.out.println("目标文件不存在");
}
}
}
}
上面的文件夹拷贝根目录并没有拷贝过去,有需要的朋友可以先创建一下根目录。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值