10.8 IO流 递归复制

 注意点

1源路径和目标路径一定不能相同
2在new Fileoutputstream时就会清空目标路径的文件内容
3就算是追加,也会出间题,边读边写问题,程序一时半会不会终出     
 

递归复制实现方法            

public class DiGui_01 {
    public static void main(String[] args) {
        File filename = new File("C:/测试文件");
        diGui(filename);
    }
    public static void diGui(File file){
        if (file.isFile()){
            //C:\测试文件\新建文件夹
            String absolutePath = file.getAbsolutePath();
            String s = "D" + absolutePath.substring(1);
            //D:\测试文件\新建文件夹
            File r1=new File(s);
          //  创建一个D盘的File  获取它的父路径   
            File parentFile = r1.getParentFile();
            //创建文件夹
           parentFile.mkdirs();


                 //复制
            try( FileInputStream in = new FileInputStream(absolutePath);
                 BufferedInputStream b=new BufferedInputStream(in);
                 FileOutputStream out = new FileOutputStream(s);
                 BufferedOutputStream bo=new BufferedOutputStream(out);



            ) {
                byte[] a=new byte[1024];
                int read = 0;
                while ((read = b.read(a))!=-1){
                    bo.write(a,0,read);

                }

            } catch (Exception e) {
                e.printStackTrace();
            }
            //复制结束
            // 递归实现
        }else{
            File[] files = file.listFiles();
            for (File eve:files) {
                diGui(eve);
            }
            



        }

    }

递归删除 

                                                                                                                                   

public class DIGui_02 {
    public static void main(String[] args) {
        File filename = new File("C:/测试文件");
            diGui(filename);
    }
    public static void diGui(File file){
        File[] dele = file.listFiles();
        if (dele != null&&dele.length > 0) {
            for (File f : dele) {
                diGui(f);
            }

        }else {
            System.out.println(file.getAbsolutePath()+"删除"+file.delete());
        }


    }

    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值