zoukankan      html  css  js  c++  java
  • 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;  
    
            }  
    
        }
    
     
    
    }
  • 相关阅读:
    计算字符个数
    字符串最后一个单词的长度
    C++面试宝典
    给定三角形ABC和一点P(x,y,z),判断点P是否在ABC内,给出思路并手写代码
    N-皇后问题(N Queens)
    图着色算法详解(Graph Coloring)
    c++学习路线连接
    数据结构--经典排序算法
    5. 最长回文子串
    4. 寻找两个有序数组的中位数
  • 原文地址:https://www.cnblogs.com/super-chao/p/11864990.html
Copyright © 2011-2022 走看看