分享一下比較兩個實體類的工具包java
package cn.mollie.utils; import java.beans.Introspector; import java.beans.PropertyDescriptor; import java.lang.reflect.Method; import java.sql.Timestamp; import java.util.ArrayList; import java.util.Arrays; import java.util.Date; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; public class CompareUtil { /** * 比較兩個實體屬性值,返回一個boolean,true則表時兩個對象中的屬性值無差別 * @param oldObject 進行屬性比較的對象1 * @param newObject 進行屬性比較的對象2 * @return 屬性差別比較結果boolean */ public static boolean compareObject(Object oldObject, Object newObject) { Map<String, List<Object>> resultMap=compareFields(oldObject,newObject,null); //System.out.println("resultMap------------"+resultMap); if(resultMap.size()>0) { return false; }else { return true; } } /** * 比較兩個實體屬性值,返回一個map以有差別的屬性名爲key,value爲一個Map分別存oldObject,newObject此屬性名的值 * @param obj1 進行屬性比較的對象1 * @param obj2 進行屬性比較的對象2 * @param ignoreArr 忽略比較的字段 * @return 屬性差別比較結果map */ @SuppressWarnings("rawtypes") public static Map<String, List<Object>> compareFields(Object obj1, Object obj2, String[] ignoreArr) { try{ Map<String, List<Object>> map = new HashMap<String, List<Object>>(); List<String> ignoreList = null; if(ignoreArr != null && ignoreArr.length > 0){ // array轉化爲list ignoreList = Arrays.asList(ignoreArr); } if (obj1.getClass() == obj2.getClass()) {// 只有兩個對象都是同一類型的纔有可比性 Class clazz = obj1.getClass(); // 獲取object的屬性描述 PropertyDescriptor[] pds = Introspector.getBeanInfo(clazz, Object.class).getPropertyDescriptors(); for (PropertyDescriptor pd : pds) {// 這裏就是全部的屬性了 String name = pd.getName();// 屬性名 if(ignoreList != null && ignoreList.contains(name)){// 若是當前屬性選擇忽略比較,跳到下一次循環 continue; } Method readMethod = pd.getReadMethod();// get方法 // 在obj1上調用get方法等同於得到obj1的屬性值 Object o1 = readMethod.invoke(obj1); // 在obj2上調用get方法等同於得到obj2的屬性值 Object o2 = readMethod.invoke(obj2); if(o1 instanceof Timestamp){ o1 = new Date(((Timestamp) o1).getTime()); } if(o2 instanceof Timestamp){ o2 = new Date(((Timestamp) o2).getTime()); } if(o1 == null && o2 == null){ continue; }else if(o1 == null && o2 != null){ List<Object> list = new ArrayList<Object>(); list.add(o1); list.add(o2); map.put(name, list); continue; } if (!o1.equals(o2)) {// 比較這兩個值是否相等,不等就能夠放入map了 List<Object> list = new ArrayList<Object>(); list.add(o1); list.add(o2); map.put(name, list); } } } return map; }catch(Exception e){ e.printStackTrace(); return null; } } }