- 概念
內(nèi)省(Introspector) 是Java 語言對(duì) JavaBean 類屬性、事件的一種缺省處理方法。JavaBean是一種特殊的類,主要用于傳遞數(shù)據(jù)信息,這種類中的方法主要用于訪問私有的字段,且方法名符合某種命名規(guī)則。如果在兩個(gè)模塊之間傳遞信息,可以將信息封裝進(jìn)JavaBean中,這種對(duì)象稱為“值對(duì)象”(Value Object),或“VO”。方法比較少。這些信息儲(chǔ)存在類的私有變量中,通過set()、get()獲得。
- PropertyDescriptor類:
PropertyDescriptor類表示JavaBean類通過存儲(chǔ)器導(dǎo)出一個(gè)屬性。主要方法:1. getPropertyType(),獲得屬性的Class對(duì)象;2. getReadMethod(),獲得用于讀取屬性值的方法;getWriteMethod(),獲得用于寫入屬性值的方法;3. hashCode(),獲取對(duì)象的哈希值;4. setReadMethod(Method readMethod),設(shè)置用于讀取屬性值的方法;5. setWriteMethod(Method writeMethod),設(shè)置用于寫入屬性值的方法。
- Introspector類:
將JavaBean中的屬性封裝起來進(jìn)行操作。在程序把一個(gè)類當(dāng)做JavaBean來看,就是調(diào)用Introspector.getBeanInfo()方法,得到的BeanInfo對(duì)象封裝了把這個(gè)類當(dāng)做JavaBean看的結(jié)果信息,即屬性的信息。
- 代碼實(shí)現(xiàn)類的屬性值比較
/**
* 對(duì)比倆個(gè)對(duì)象相同字段修改前后值的變化 --工具類
* @param obj1 新的對(duì)象
* @param obj2 舊的對(duì)象
* @param ignoreArr
* @return
*/
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) {
ignoreList = Arrays.asList(ignoreArr);
}
// 只有兩個(gè)對(duì)象都是同一類型的才有可比性
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();
// 如果當(dāng)前屬性選擇忽略比較,跳到下一次循環(huán)
if (ignoreList != null && ignoreList.contains(name)) {
continue;
}
// get方法
Method readMethod = pd.getReadMethod();
// 在obj1上調(diào)用get方法等同于獲得obj1的屬性值
Object o1 = readMethod.invoke(obj1);
// 在obj2上調(diào)用get方法等同于獲得obj2的屬性值
Object o2 = readMethod.invoke(obj2);
if (o1 == null) {
continue;
}
if (o1 instanceof Date && o2 instanceof Date) {
o1 = ((Date) o1).getTime();
o2 = ((Date) o2).getTime();
}
// 比較這兩個(gè)值是否相等,不等就可以放入map了
if (!o1.equals(o2)) {
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;
}
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。