说到代理,大家肯定都有接触过。毕竟当有些事务不想亲自处理时,会选择委托给别人进行解决。那么在java中也有着这样的机制,叫做代理模式。主要分为两大类:静态代理和动态代理。一种是运行前就存在,另一种是运行后才进行创建。下面我们就java中的两种代理模式进行讲解。
1.静态代理
由程序员创建或者由第三方工具生成,再进行编译;在程序运行之前,代理类的.class文件已经存在了。静态代理通常只代理一个类,并且要事先知道代理的是什么。
public class BlogStaticProxy implements IBlogService{ private IBlogService blogService; public BlogStaticProxy(IBlogService blogService) { this.blogService = blogService; } @Override public void writeBlog() { System.out.println("start writing..."); blogService.writeBlog(); System.out.println("end writing..."); } }
2.动态代理
动态代理的代理类在程序运行前是不存在的,也就是说代理类在程序运行时才创建的代理模式成为动态代理。这种情况下,代理类并不是在Java代码中定义好的,而是在程序运行时根据我们的在Java代码中的“指示”动态生成的。
public class MainClass { public static void main(String[] args) { //1、创建一个真实角色 Singer target = new Singer(); //2、调用Proxy.newProxyInstance方法,并构造一个InvocationHandler对象, //3、在对象内部重写invoke方法,同时调用method.invoke(target,args); //4、并在该方法的上下添加自己的代码逻辑 //其中:target.getClass().getClassLoader():获取类加载器,用来生成代理对象; // target.getClass().getInterfaces()获取接口元信息; ISinger iSinger = (ISinger) Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), new InvocationHandler() { @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("动态代理---向观众问好");//在真实对象的方法被调用“前”编写自己的业务逻辑 Object returnValue = method.invoke(target,args);//此处通过反射调用真实对象对应的方法; System.out.println("动态代理---向观众问好");//在真实对象的方法被调用“后”编写自己的业务逻辑 return returnValue; } }); iSinger.sing(); } } //测试结果 "C:\Program Files\Java\jdk1.8.0_211\bin\java.exe" "-javaagent:C:\Program....... 动态代理---向观众问好 sing a song 动态代理---向观众问好 Process finished with exit code 0
以上就是java代理模式的分类,学习完本篇的内容后,想必大家已经能对静态代理和动态代理有所区分。在实际使用时,可以根据需求自行选择。