下面是一个 Java 代码示例,演示如何递归地拷贝一个文件夹及其所有子文件夹和文件。这个示例使用了 Java 的 IO 流和递归技巧来实现文件夹拷贝功能。
package IoStream.Case;
import java.io.*;
public class FileCopy
{
//文件拷贝,包含子文件夹
public static void main(String[] args) throws IOException
{
File file = new File(".\\mnb");//源文件
File file1 = new File(".\\dest");//目的文件
copyFile(file,file1);
}
public static void copyFile(File file,File dest) throws IOException
{
dest.mkdirs();//创建文件夹
File[] files = file.listFiles();//获取源文件内容
for (File f : files)//循环遍历
{
if (f.isFile())//是文件则拷贝
{
FileInputStream fis = new FileInputStream(f);
FileOutputStream fos = new FileOutputStream(new File(dest,f.getName()));//写入的文件位置
byte[] bytes = new byte[1024*1024];
int len;
while ((len = fis.read(bytes)) != -1)
{
fos.write(bytes,0,len);
}
fos.close();
fis.close();
}
else//不是文件则递归
{
copyFile(f,new File(dest,f.getName()));
}
}
}
}
以上代码还是使用了文件处理中的万能模板
套路:
1,进入文件夹
2,遍历数组
3,判断(判断是否为文件,按照文件要求操作)
4,判断(判断是否为文件夹,按照文件夹要求操作)