文章目录
- 1. 简介
- 2. 代码
- 3. 参考链接
1. 简介
代理类在程序运行时创建的代理方式被成为动态代理。在静态代理中,代理类(RenterProxy)是自己已经定义好了的,在程序运行之前就已经编译完成。而动态代理是在运行时根据我们在Java代码中的“指示”动态生成的。动态代理相较于静态代理的优势在于可以很方便的对代理类的所有函数进行统一管理,如果我们想在每个代理方法前都加一个方法,如果代理方法很多,我们需要在每个代理方法都要写一遍,很麻烦。而动态代理则不需要。
spring 中aop便是基于代理进行的
2. 代码
需要代理的用户
一个大明星
public class BigStar implements Star{private String name;public BigStar(String name){this.name = name;}public String sing(String name){System.out.println(this.name + "在唱" + name);return "谢谢!!!";}public void dance(){System.out.println(this.name + "跳舞!!!");}
}
遵守规则,写个接口
public interface Star {String sing(String name);void dance();
}
我是代理工厂
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;public class ProxyUtil {public static Star createProxy(BigStar bigStar){/** public static Object newProxyInstance(ClassLoader loader,Class<?>[] interfaces,InvocationHandler h)*/Star starProxy = (Star)Proxy.newProxyInstance(ProxyUtil.class.getClassLoader(), new Class[]{Star.class}, new InvocationHandler() {@Overridepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable {if(method.getName().equals("sing")){System.out.println("准备话筒,收钱");}else if(method.getName().equals("dance")){System.out.println("场地准备中。。。收钱。。。");}return method.invoke(bigStar, args);}});return starProxy;}
}
测试类
public class Test {public static void main(String[] args) {BigStar bigStar = new BigStar("岳轩子");Star starProxy = ProxyUtil.createProxy(bigStar);String rs = starProxy.sing("恭喜发财");System.out.println(rs);starProxy.dance();}
}
运行结果:
准备话筒,收钱
岳轩子在唱恭喜发财
谢谢!!!
场地准备中。。。收钱。。。
岳轩子跳舞!!!
3. 参考链接
java动态代理
【黑马磊哥】Java动态代理深入剖析,真正搞懂Java核心设计模式:代理设计模式