思路部分来自于
链接: 怎样用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, ""));
}
}
}
}