为了对代码进行简化,在得到dao时不必每次都写出拿到dao的方法,可以使用依赖注入的方式.
依赖注入有2种方式:
1.基于setXX的方式:判断有无setXX的方法,如果有,则将xx对象注入
具体代码:
public static void diDao(Object object) {
Method[] methods = object.getClass().getDeclaredMethods();
try {
for(Method m:methods) {
String methodName = m.getName();
if(methodName.startsWith("set")) {
methodName = methodName.substring(3);
methodName = methodName.substring(0,methodName.length()-3);
methodName = methodName.toLowerCase();
Object obj = DaoUtil.createDaoFactory().getDao(methodName);
m.invoke(object, obj);
}
}
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}
该方式的缺点:当有其它非getXXDao方法时,该方式就会找不到对应的对象,运行时会报错.
2.基于annotation的方式: anootation相当于一个标签,当某个方法被贴上了这个标签,就将xx对象注入
具体代码:
public static void diDao(Object object) {
Method[] methods = object.getClass().getDeclaredMethods();
try {
for(Method m:methods) {
if(m.isAnnotationPresent(ShopDi.class)) {
ShopDi sd = m.getAnnotation(ShopDi.class);
String value = sd.value();
if(value == null || "".equals(value.trim())) {
value = m.getName().substring(3);
value = value.substring(0,value.length()-3).toLowerCase();
}
Object obj = DaoUtil.createDaoFactory().getDao(value);
m.invoke(object, obj);
}
}
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}
3.除了这2种方式外,还可以写一个properties文件,列出所有需要进行依赖注入的方法,比较繁琐,不予考虑