java实现文件比较2,仅根据文件路径判断

思路部分来自于
链接: 怎样用java实现文件比较,判断是否是同一个文件

该链接中仅以两个文件夹下不同文件,进行互相比较,
仅以文件名为区别点,

我于其基础上,
1.增加递归获取文件夹下所有文件
2.对获取的所有文件增加md5值获取并比对md5值
: java实现文件比较1,根据文件路径与md5判断是否是同一个文件

但有更快的方法,
java实现文件比较2,仅根据文件路径判断
java实现文件比较2,使用set的去重属性,同样递归获取所有文件,但大批量文件比对更快
即本文

该方法速度特别快
1w左右文件几秒钟左右
但还有个缺点,没办法判断内容修改

也有最新的的思路方法
java实现文件比较3,判断文件是否新增减少修改
该方法速度快
修改后可以判断内容修改


package com.taiyusoft;

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

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


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


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

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


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


//以数据1为主 增加数据2
        List listoneNot1 = new ArrayList<>(); //存放数据一缺失的数据
        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(linkedList1.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+listoneNot1.get(i));
            }
        }else{
            System.out.println("无");
        }


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

//以数据2为主 增加数据1
        List listoneNot2 = new ArrayList<>(); //存放数据一缺失的数据
        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+listoneNot2.get(i));
            }
        }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, ""));
                        } else if (files[i].isDirectory()) {
                            readFileSum1(files[i], dirName1);
                        }
                        files[i] = null;
                    }
                }
                files = null;
            } else if (root.isFile()) {
                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()) {
                            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()) {
                linkedList2.add(root.toString().replace(dirName2, ""));
            }
        }
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值