最近在寫一個數(shù)據(jù)接口,業(yè)務(wù)寬表有60幾個字段,在生成mysql表對應(yīng)的實體類時可以借助idea的datasource工具導(dǎo)出成員變量,這倒是方便了不少。但是隨后在接口輸出對象時,遇到了成員變量的動態(tài)選擇問題,因為有時候只需要幾個成員變量的值,如果整個對象所有成員變量生成json會造成不必要的字段填充。這塊就想到了根據(jù)成員變量名字,運(yùn)用反射機(jī)制動態(tài)調(diào)用成員函數(shù)。比起整個類的反射,這個相對簡單。
//參數(shù)instance可以隨便傳需要的對象實例,methodName是類的public方法名
private Object getMethodO(Object instance, String methodName) {
try {
Method get = instance.getClass().getMethod(methodName);
Object result = get.invoke(instance);
return result;
} catch (Exception e) {
logger.error(e.getMessage());
}
return null;
}