java实现文件比较3,判断文件是否新增减少修改

思路
思路部分来自于怎样用java实现文件比较,判断是否是同一个文件
最早的
java实现文件比较,根据文件路径与md5判断是否是同一个文件
接上文set的去重
java实现文件比较2,仅根据文件路径判断

最终的

重写了equals 与hashCode方法
使set中存储对象fc ,对象中包含了之前没有的文件最后修改时间属性,
但速度同样很快
不仅能发现两路径文件夹下,
那个文件夹有自己独有的文件
还能发现修改的文件


package com.taiyusoft;

import java.io.File;
import java.util.*;

public class set2 {
    private static LinkedList<Fc> linkedList1=new LinkedList<>();//读取路径1中的所有的文件


    private static  LinkedList<Fc> linkedList2=new LinkedList<>();//读取路径2中的所有的文件


    public static void main(String[] args) {
        System.out.println("123123");
        String dirName1 = "C:\\Users\\taiyu\\Desktop\\4444\\file1\\";
        File file = new File(dirName1);
        readFileSum1(file, dirName1);

        String dirName2 = "C:\\Users\\taiyu\\Desktop\\file2\\";
        File file1 = new File(dirName2);
        readFileSum2(file1, dirName2);


        Set setOne1 = new HashSet<Fc>();
        setOne1.addAll(linkedList1);  //可以通过addAll把list集合转换为set集合


//以数据1为主 增加数据2
        List listoneNot1 = new ArrayList<Fc>(); //存放数据一缺失的数据
        int setOneSize1 = setOne1.size(); //数据一大小
        for (int i = 0; i < linkedList2.size(); i++) { //数据二
            setOne1.add(linkedList2.get(i));
            if (setOne1.size() != setOneSize1) {  //判断大小是否改变 ,改变表示数据缺失
                listoneNot1.add(linkedList2.get(i)); //存放缺失了哪些数据
                setOne1.remove(linkedList2.get(i));
                setOneSize1 = setOne1.size(); //更新基础集合大小
            }
        }

        //打印缺失数据
        if(listoneNot1.size()>0){
            System.out.println("数据1缺失的文件");
            for (int i = 0; i < listoneNot1.size(); i++) {
                System.out.println(dirName1+""+((Fc) listoneNot1.get(0)).getPath());
            }
        }else{
            System.out.println("无");
        }


        Set setOne2 = new HashSet<Fc>();
        setOne2.addAll(linkedList2);  //可以通过addAll把list集合转换为set集合

//以数据2为主 增加数据1
        List listoneNot2 = new ArrayList<Fc>(); //存放数据一缺失的数据
        int setOneSize2 = setOne2.size();
        for (int i = 0; i < linkedList1.size(); i++) { //数据二
            setOne2.add(linkedList1.get(i));

            if (setOne2.size() != setOneSize2) {  //判断大小是否改变 ,改变表示数据缺失
                listoneNot2.add(linkedList1.get(i)); //存放缺失了哪些数据
                setOne2.remove(linkedList1.get(i));
                setOneSize2 = setOne2.size(); //更新基础集合大小
            }
        }

        //打印缺失数据
        if(listoneNot2.size()>0){
            System.out.println("数据2缺失文件");
            for (int i = 0; i < listoneNot2.size(); i++) {
                System.out.println(dirName2+""+((Fc) listoneNot2.get(i)).getPath());
            }
        }else{
            System.out.println("无");
        }


    }

    private static void readFileSum1(File root, String dirName1) {

        if (root.exists()) {
            if (root.isDirectory()) {
                File[] files = root.listFiles();
                if (files != null) {
                    for (int i = 0; i < files.length; i++) {
                        if (files[i].isFile()) {
//                             linkedList1.add(files[i].toString().replace(dirName1, ""));
                            Fc fc = new Fc();
                            fc.setPath(files[i].toString().replace(dirName1, ""));
                            fc.setLastmodified(String.valueOf(files[i].lastModified()));
                            linkedList1.add(fc);

                        } else if (files[i].isDirectory()) {
                            readFileSum1(files[i], dirName1);
                        }
                        files[i] = null;
                    }
                }
                files = null;
            } else if (root.isFile()) {
                Fc fc = new Fc();
                fc.setPath(root.toString().replace(dirName1, ""));
                fc.setLastmodified(String.valueOf(root.lastModified()));
                linkedList1.add(fc);
//                linkedList1.add(root.toString().replace(dirName1, ""));
            }
        }
    }

    private static void readFileSum2(File root, String dirName2) {

        if (root.exists()) {
            if (root.isDirectory()) {
                File[] files = root.listFiles();
                if (files != null) {
                    for (int i = 0; i < files.length; i++) {
                        if (files[i].isFile()) {
                            Fc fc = new Fc();
                            fc.setPath(files[i].toString().replace(dirName2, ""));
                            fc.setLastmodified(String.valueOf(files[i].lastModified()));
                            linkedList2.add(fc);
//                            linkedList2.add(files[i].toString().replace(dirName2, ""));
                        } else if (files[i].isDirectory()) {
                            readFileSum2(files[i], dirName2);
                        }
                        files[i] = null;
                    }
                }
                files = null;
            } else if (root.isFile()) {
                Fc fc = new Fc();
                fc.setPath(root.toString().replace(dirName2, ""));
                fc.setLastmodified(String.valueOf(root.lastModified()));
                linkedList2.add(fc);
//                linkedList2.add(root.toString().replace(dirName2, ""));
            }
        }
    }
}




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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值