动态代理Java实现
思考:在IBuyWatermelon添加一個方法selectWatermelon()
靜態代理中需要在RealSubject中實現該方法,而且Proxy也要實現該方法調用RealSubject中的實現,如果再增加10個方法還是得這樣操作,導致大量的代碼重復。
現在來看動態代理(顧名思義,是在運行時才形成的代理對象,不像靜態代理在編譯時就載入代理對象)。
生成動態代理的方法有很多: JDK中自帶的動態代理java.lang.reflect.*, CGlib等
下面的例子是JDK中自帶的動態代理java.lang.reflect.*
?
IBuyWatermelon():接口
package com.maggie.dynamicproxy;public interface IBuyWatermelon {//代理事件public abstract String buyWatermelon();public abstract void selectWatermelon(); }?
BuyWatermelonImpl:實現類
package com.maggie.dynamicproxy;//可理解成被代理者 public class BuyWatermelonImpl implements IBuyWatermelon {private Supermarket supermaket;public BuyWatermelonImpl(Supermarket supermaket) {super();this.supermaket = supermaket;}@Overridepublic String buyWatermelon() {System.out.println("在"+supermaket.getName()+" 買西瓜");return "watermelon";}@Overridepublic void selectWatermelon() {System.out.println("選擇無籽西瓜");}}?
ProxyFactory:代理對象類(核心代碼)
package com.maggie.dynamicproxy;import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy;public class ProxyFactory {//維護一個目標對象private Object target;public ProxyFactory(Object target){this.target=target;}//給目標對象生成代理對象public Object getProxyInstance(){//動態代理的核心,涉及到反射return Proxy.newProxyInstance(target.getClass().getClassLoader(),target.getClass().getInterfaces(),new InvocationHandler() {@Overridepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable {//執行目標對象方法Object returnValue = method.invoke(target, args);return returnValue;}});} }客戶端調用
package com.maggie.dynamicproxy;public class Main {public static void main(String[] args) {Supermarket zhaoLiu = new Supermarket();zhaoLiu.setName("趙六超市");IBuyWatermelon target = new BuyWatermelonImpl(zhaoLiu);//被代理的對象//創建代理對象IBuyWatermelon hourskeeper = (IBuyWatermelon) new ProxyFactory(target).getProxyInstance();hourskeeper.buyWatermelon();hourskeeper.selectWatermelon();} }輸出
在趙六超市 買西瓜 選擇無籽西瓜?
現在就算IBuyWatermelon的方法再怎么增加,也只需要在BuyWatermelonImpl實現,就可以在客戶端調用,不會出現大量的重復代碼。
從靜態代理到動態代理都圍繞著賣瓜事件,為了前后方便比較,但是動態代理并沒完,里面的源碼機制才是核心關鍵
public static Object newProxyInstance(ClassLoader loader,Class<?>[] interfaces,InvocationHandler h)這個方法是整個動態代理實現的關鍵
?
轉載于:https://www.cnblogs.com/maggiejyt/p/7569123.html
總結
以上是生活随笔為你收集整理的动态代理Java实现的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 在JS中如何判断所输入的是一个数、整数、
- 下一篇: Java的for-each循环