动态代理模式

动态代理模式属于比较困难的一个设计模式。
开发中用到的很少,因为动态代理模式的应用场景是搭建框架,对于大部分人而言能用就可以了,根本没机会写。
但是动态代理模式学习掌握明白去分析可以源码很有帮助了。

 

一:静态代理模式

 

事物的发展是有规律的,现有静态才会有动态的需求。
代理模式给某一个对象提供一个代理对象,并由代理对象控制对原对象的引用。通俗的来讲代理模式就是我们生活中常见的中介。

静态代理在使用时,需要定义接口或者父类,被代理对象与代理对象一起实现相同的接口或者是继承相同父类。一般来说,被代理对象和代理对象是一对一的关系,当然一个代理对象对应多个被代理对象也是可以的。
静态代理,一对一则会出现时静态代理对象量多、代码量大,从而导致代码复杂,可维护性差的问题。一对多则代理对象会出现扩展能力差的问题。
方案一:一对一,100个真实对象需要代理,那就写出100个代理对象去代理,代码多,修改工作量巨大。
方案二:一对多,100个真实对象公用一个代理,那就需要1个代理和100个真实对象同时产生关系,关系非常复杂很难扩展。

所以静态代理局限性很大,只适合明确知道真实对象是谁,而且数量不多情况下。
如果不知道真实对象的名字,不知道会有多少真实对象需要代理的情况下根本无法使用
具体代码:

 

 

 

image.png

image.png

 

image.png

image.png

二:反射
静态存在局限,那只有动态代理去解决了
那就需要用到反射
Reflection(反射)是Java被视为动态语言的关键,反射机制允许程序在执行期借助于Reflection API取得任何类的內部信息,并能直接操作任意对象的内部属性及方法。

 

反射就是在运行时才知道要操作的类是什么,并且可以在运行时获取类的完整构造,并调用对应的方法。
在运行时构造任意一个类的对象
在运行时获取任意一个类所具有的成员变量和方法
在运行时调用任意一个对象的方法(属性)

三动态代理模式

 

image.png

image.png

image.png

image.png

 

image.png

image.png

优点
只需要1个动态代理类就可以解决创建多个静态代理的问题,避免重复、多余代码,更强的灵活性
动态代理的服务内容不需要像静态代理一样写在每个代码块中,只需要写在invoke()方法中即可,降低了代码的冗余度。

缺点
效率低,相比静态代理中 直接调用目标对象方法,动态代理则需要先通过Java反射机制 从而 间接调用目标对象方法
动态代理类仍然需要实现接口。

静态代理,动态代理测试代码
如果喜欢请点个start

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
动态代理是一种非常常用的设计模式,它可以在运行时创建代理对象,而不是在编译时创建。下面是一个使用Java动态代理模式的示例代码: 首先,定义一个接口: ```java public interface Subject { void doSomething(); } ``` 然后,创建一个实现该接口的类: ```java public class RealSubject implements Subject { @Override public void doSomething() { System.out.println("RealSubject.doSomething()"); } } ``` 接下来,创建一个代理类,它实现了InvocationHandler接口: ```java import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; public class ProxyHandler implements InvocationHandler { private Object target; public ProxyHandler(Object target) { this.target = target; } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("Before method " + method.getName() + " is called."); Object result = method.invoke(target, args); System.out.println("After method " + method.getName() + " is called."); return result; } } ``` 最后,我们可以使用以下代码创建并使用代理对象: ```java import java.lang.reflect.Proxy; public class Client { public static void main(String[] args) { RealSubject realSubject = new RealSubject(); ProxyHandler proxyHandler = new ProxyHandler(realSubject); Subject proxySubject = (Subject) Proxy.newProxyInstance(Subject.class.getClassLoader(), new Class[]{Subject.class}, proxyHandler); proxySubject.doSomething(); } } ``` 输出结果如下: ``` Before method doSomething is called. RealSubject.doSomething() After method doSomething is called. ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值