代理模式 之动态代理
动态代理中:
1)代理类不需要实现接口(这个不需要实现接口,是指不需要实现目标类实现的接口);
2)代理对象的生成,是利用JDK中的API函数,动态的在内存中构建代理对象(需要我们指定创建代理对象(或者可以说是指定目标对象)的接口类型;
3)动态代理又叫JDK代理,接口代理
JDK中生成代理对象的API:
java.lang.reflect
类Proxy
public static Object newProxyInstance(
ClassLoader loader, //定义类的类加载器
Class<?>[] interfaces, //代理类需要实现的接口列表,即为目标对象实现的接口的类型,也是构建代理对象要实现的接口类型
InvocationHandler h //指派方法调用的调用处理程序,即事件处理器
);
返回一个指定接口的代理实例,该接口可以将方法调用指派到指定的调用处理程序。
返回:
一个带有代理类的指定调用处理程序的代理实例,它由指定的类加载器定义,并实现指定的接口。
此方法相当于:
Proxy.getProxyClass(loader,interfaces).getConstructor(new Class[]{InvocationHandler.class}).newInstance(new Object[]{handler});
思路:
1.创建接口(声明方法) 2.创建接口的实现类(作为目标类),重写接口中的方法;
3.创建代理类(无需实现上述创建的接口)
代理类中的代码写法为:
//通过该类返回一个代理对象
public class FactoryProxy {
//维护目标对象
//目标对象设置为Object的类型,是为了便于为其他(目标)对象创建代理对象
private Object target;
//构造方法,为成员变量初始化,指明目标对象
public FactoryProxy(Object target){
this.target = target;
}
//给目标对象生成代理对象
public Object getProxyInstance(){
return Proxy.newProxyInstance(target.getClass().getClassLoader(),
target.getClass().getInterfaces(),
new InvocationHandler(){
@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
// TODO Auto-generated method stub
System.out.println("开启事务管理");
//执行目标方法
Object returnValue = method.invoke(target, args);
System.out.println("提交事务");
return returnValue;
}
});
}
}
动态代理总结:
代理类不需要实现目标类实现的接口,但是目标类必须实现接口;否则不能使用动态代理。