http://numen06.iteye.com/blog/1428067
http://numen06.iteye.com/blog/1439763
上一篇文章已经将封装转换类,独立出来并作为一个类来进行。
在实际运用过程的中会遇到初始化的时候先后问题,所以将装换借口直接做成static只是作为工具类运用。
package com.wesley.framework.decoration;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.apache.commons.beanutils.BeanUtils;
import org.apache.commons.collections.MapUtils;
import com.wesley.framework.commen.ArrayUtil;
import com.wesley.framework.commen.ObjectUtil;
import com.wesley.framework.commen.reflect.ClassUtil;
import com.wesley.framework.commen.reflect.ReflectionUtils;
public class DecoratorFactory {
@SuppressWarnings({ "unchecked"})
public synchronized static <Model, Decor extends Decorator<Model>, SuperDec extends Decorator<?>> Decor exchange(
SuperDec superDec, Class<Decor> clazz, String propertyName,
String... params) {
Decor decor = null;
try {
decor = ClassUtil.newInstance(clazz);
Model model = (Model) ReflectionUtils.invokeGetterMethod(
superDec.getModel(), propertyName);
if (ObjectUtil.isEmpty(model)) {
ReflectionUtils.invokeSetterMethod(superDec, propertyName,
decor);
return decor;
}
Map<String, String> map = ArrayUtil.toMap(params);
if (!MapUtils.isEmpty(map))
BeanUtils.populate(decor, map);
decor.setModel(model);
} catch (Exception e) {
e.printStackTrace();
}
return decor;
}
public synchronized static <Model, Decor extends Decorator<Model>> Decor exchange(
Class<Decor> clazz, Model model, String... params) {
Decor decor = null;
try {
if (ObjectUtil.isEmpty(model))
return null;
decor = ClassUtil.newInstance(clazz);
Map<String, String> map = ArrayUtil.toMap(params);
if (!MapUtils.isEmpty(map))
BeanUtils.populate(decor, map);
decor.setModel(model);
} catch (Exception e) {
e.printStackTrace();
}
return decor;
}
@SuppressWarnings("unchecked")
public static <Model, Decor extends Decorator<Model>> List<Decor> exchange(
Decor dec, Collection<Model> models, String... params) {
List<Decor> decorList = new ArrayList<Decor>();
try {
for (Model model : models) {
decorList.add((Decor) DecoratorFactory.exchange(dec.getClass(),
model, params));
}
} catch (Exception e) {
e.printStackTrace();
}
return decorList;
}
public static <Model, Decor extends Decorator<Model>> List<Decor> exchange(
Class<Decor> clazz, Collection<Model> models, String... params) {
List<Decor> decorList = new ArrayList<Decor>();
try {
for (Model model : models) {
decorList.add(DecoratorFactory.exchange(clazz, model, params));
}
} catch (Exception e) {
e.printStackTrace();
}
return decorList;
}
public static <Model, Decor extends Decorator<Model>> Set<Model> exchange(
Collection<Decor> decs, String... params) {
Set<Model> decorList = new HashSet<Model>();
try {
for (Decor dec : decs) {
Model model = dec.getModel();
Map<String, String> map = ArrayUtil.toMap(params);
if (!MapUtils.isEmpty(map))
BeanUtils.populate(model, map);
decorList.add(model);
}
} catch (Exception e) {
e.printStackTrace();
}
return decorList;
}
}
package com.wesley.framework.decoration;
import org.apache.struts2.json.annotations.JSON;
import com.wesley.framework.commen.reflect.GenericsUtils;
@SuppressWarnings("serial")
public abstract class DecoratorModel<Model> implements Decorator<Model> {
private Model model;
// protected DecoratorHelper<Model, ? extends Decorator<Model>> helper;
/**
* 装饰器构造函数,如果没有自动创建一个实体
*/
@SuppressWarnings("unchecked")
public DecoratorModel() {
super();
try {
Class<Model> cls = GenericsUtils.getSuperClassGenricType(
this.getClass(), 0);
this.setModel(cls.newInstance());
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
/**
* @param model
* 将实体封装进入装饰器
*/
public DecoratorModel(Model model) {
super();
this.setModel(model);
}
@JSON(serialize = false)
@Override
public final Model getModel() {
return this.model;
}
/*
* (non-Javadoc)
*
* @see com.wesley.framework.decoration.Decorator#setModel(java.lang.Object)
* 装饰器接口,将Model注入到装饰器中
*/
@Override
public void setModel(Model model) {
this.model = model;
// helper = new DecoratorHelper<Model,Decorator<Model>>(
// (Class<Decorator<Model>>) this.getClass());
}
// /*
// * (non-Javadoc)
// *
// * @see
// *
// com.wesley.framework.decoration.Decoration#baseExchange(java.lang.Object)
// *
// * 反射必有参数构造函数,将实体包含在装饰器之中
// */
// @SuppressWarnings("unchecked")
// @Override
// public Decor baseExchange(Model model) {
// Decor decor = null;
// try {
// decor = (Decor) this.getClass().getConstructor(model.getClass())
// .newInstance(model);
// } catch (InstantiationException e) {
// e.printStackTrace();
// } catch (IllegalAccessException e) {
// e.printStackTrace();
// } catch (IllegalArgumentException e) {
// e.printStackTrace();
// } catch (SecurityException e) {
// e.printStackTrace();
// } catch (InvocationTargetException e) {
// e.printStackTrace();
// } catch (NoSuchMethodException e) {
// e.printStackTrace();
// }
// decor.setModel(model);
// return decor;
// }
//
// /*
// * (non-Javadoc)
// *
// * @see
// *
// com.wesley.framework.decoration.Decoration#baseExchange(java.util.Collection
// * 转换List等Collection接口数据
// */
// @Override
// public List<Decor> baseExchange(Collection<Model> models) {
// List<Decor> decorList = new ArrayList<Decor>();
// for (Model model : models) {
// decorList.add(this.baseExchange(model));
// }
// return decorList;
// }
}
分享到:
相关推荐
1. 适配器模式:将两个不兼容的接口转换为可以协同工作的接口,常用于集成第三方库或旧系统。 2. 装饰器模式:动态地给对象添加一些额外的职责,提供了比继承更多的灵活性。 3. 代理模式:为其他对象提供一种代理以...
这通常发生在需要将数值从精度较高的类型转换为精度较低的类型,或者在处理对象时需要明确指定子类对象为父类类型的情况。在“java 常用基础类型之强制转换”这个主题中,我们将深入探讨Java中的基本数据类型转换...
本资源“java设计模式并附带源码”提供了一种深入理解并实践Java设计模式的方式,通过源码实例帮助开发者更直观地学习和掌握这些模式。 首先,我们要了解设计模式的基本分类,它们主要分为三类:创建型模式...
外观模式是一种常见的简化复杂系统结构的模式,它为子系统中的一组接口提供一个一致的界面,定义了一个高层接口,使得子系统更加容易使用。外观模式通过封装复杂系统的一部分,提供一个统一的接口来降低系统的复杂度...
"适配器模式"允许类之间的接口不兼容的类协同工作,通过创建一个适配器类,将旧的接口转换成期望的新接口。"模板方法模式"在父类中定义了一个操作中的算法骨架,而将一些步骤延迟到子类中,使得子类可以不改变一个...
在Java编程语言中,多态性(Polymorphism)是面向对象编程的三大特性之一,另外两个是封装和继承。多态性允许我们使用一个通用的接口来处理不同类型的对象,增强了代码的灵活性和可扩展性。本篇将深入探讨Java多态中...
Java中的Observer接口和Observable类提供了观察者模式的实现。 20. **状态模式(State)**:允许对象在其内部状态改变时改变其行为,对象看起来似乎修改了它的类。在Java中,状态通常通过实现接口或继承来切换。 ...
Java设计模式源码集合了23种经典的设计模式,为高级Java开发者提供了深入理解这些模式的实际应用。下面,我们将详细探讨这些设计模式及其在Java中的实现。 1. **单例模式(Singleton)**:保证一个类只有一个实例,...
- **外观模式**:提供一个简单的接口来封装一系列复杂的子系统,简化客户端的使用。 - **享元模式**:运用共享技术有效地支持大量细粒度的对象,减少内存占用。 - **代理模式**:为其他对象提供一种代理以控制对...
结构型模式中的适配器模式能将不兼容的接口转换为可以互相操作的形式,这在对接第三方库时非常有用。装饰器模式可以在运行时动态地给对象添加新的行为或职责,避免修改已有代码。代理模式可以为其他对象提供一种代理...
- 适配器模式:将不兼容的接口转换为客户期望的接口。 - 装饰器模式:动态地给对象添加新的功能,同时保持原有接口不变。 - 代理模式:为其他对象提供一种代理以控制对这个对象的访问。 - 观察者模式:定义对象...
在Java中,设计模式分为三类:创建型模式、结构型模式和行为型模式。 创建型模式关注于对象的创建,它们包括: 1. 单例模式(Singleton):确保一个类只有一个实例,并提供全局访问点。 2. 工厂方法模式(Factory ...
6. **适配器模式 (Adapter Pattern)**:将两个不兼容的接口转换为可以一起工作的形式,使原有代码和新需求可以协同工作。 7. **策略模式 (Strategy Pattern)**:定义一系列的算法,并将每一个算法封装起来,使它们...
6. **适配器模式**:将一个类的接口转换成客户希望的另一个接口。Java中通过继承或组合来实现适配。 7. **桥接模式**:将抽象部分与实现部分分离,使它们可以独立变化。Java中可以使用接口和多态实现。 8. **装饰...
对于每个第三方接口,可以创建对应的子类,重写父类中的方法以适应特定接口的需求。 8. **日志记录**:使用如Log4j或SLF4J的日志框架记录调用接口的过程,包括请求信息、响应结果和任何异常,以便于排查问题和监控...
7. **适配器模式**:适配器模式使两个不兼容的接口能够协同工作,通过创建一个适配器类来转换原接口。 8. **桥接模式**:桥接模式将抽象部分与它的实现部分分离,使它们可以独立变化。这种模式可以减少类的数量,...
**封装**:在Java中,封装是隐藏类内部的实现细节,只对外提供公共接口来访问。在前端模块化中,我们可以使用立即执行函数表达式(IIFE)或者ES6的模块系统(import/export)来实现类似的功能,将数据和功能封装在...
- **定义**:为子系统中的一组接口提供一个一致的界面,门面模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。 - **应用场景**:简化复杂的子系统的使用。 - **实现**:创建一个单一的类,作为整个...