平时一直在用spring,spring中最大的特效IOC和AOP,其中AOP使用的就是代理模式.闲着无聊,随手写了一个代理模式,也记录下代理模式的实现Demo.java
好比如今有一个场景是:客户想要增长一个新的功能,按照流程应该是客户通知苦逼程序员增长功能,可是有一个问题,程序员并不清楚功能合理性与否,因此流程变为,客户找到项目经理,项目经理评估后,决定要作,则通知程序员加班作出来...程序员
在这个场景中,使用者是客户,实现者是程序员,代理角色则是项目经理.代理模式简单来讲就是使用者须要实现一个功能,可是不关心底层由谁实现,经过代理类能够自动匹配实现类的实现方法.好比在某些方法上须要作一些预处理,在代理类中,能够统一添加.好比上边例子,项目经理须要作一个时间统计,若是不用动态代理,有100个方法的话,就须要写100次相同的代码,极其麻烦.通常实现有两种方式:静态代理和动态代理,这里只写动态代理.spring
代码以下:ide
功能接口:ICoder.java测试
public interface ICoder {
public abstract void implDemands(String demandName);
}this
功能实现类:Coder.java.net
public class Coder implements ICoder {
private String name;
public Coder(String name) {
this.name = name;
}
@Override
public void implDemands(String demandName) {
System.out.println(name + "用JAVA实现了" + demandName + "的需求!");
}
}代理
代理类:ProxyCoder.javacode
须要实现InvocationHandler接口,实现其中的方法invoke接口
public class ProxyCoder implements InvocationHandler{
private ICoder coder;
public ProxyCoder(ICoder coder) {
this.coder = coder;
}
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException {
Object result = method.invoke(coder, args);
return result;
}
}
测试类:
public static void main(String[] args) {
ICoder coder = new Coder("张三");
InvocationHandler proxyCoder = new ProxyCoder(coder);
ClassLoader classLoader = coder.getClass().getClassLoader();
ICoder proxy = (ICoder)Proxy.newProxyInstance(classLoader, coder.getClass().getInterfaces(), proxyCoder);
proxy.implDemands("张经理");
}
即实现动态代理.