JAVA模式之代理模式

平时一直在用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("张经理");
    }

即实现动态代理.

相关文章
相关标签/搜索