java代理模式学习笔记
生活随笔
收集整理的這篇文章主要介紹了
java代理模式学习笔记
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
代理模式:為其他對象提供一種代理以控制對這個對象的訪問。在某些情況下,一個對象不適合或者不能直接引用另一個對象,而代理對象可以在客戶端和目標對象之間起到中介的作用。
- 代理類和被代理類必須實現同一個接口。
- 代理類的核心是做功能的增強,真正的服務還是目標對象提供的。(代理類必學持有被代理的對象)。
java的三種代理模式:
優點:遵循開閉原則,實現功能的擴展,
缺點:需要知道代理的目標,需要實現同一個接口,不方便進一步的擴展,如果接口改變,則都要修改。
代碼:
由Caller類調用TargetImp,TargetImp實現了Target接口,然后由Myproxy類來實現TargetImp的增強。
/*** Created by huangyj 2018/5/24.*/ public class Caller {public void calling(Target target) {System.out.println("開始調用目標類.....");target.doing();} }/*** 調用的目標-被調用者* Created by huangyj on 2018/5/24.*/ public interface Target {boolean doing(); }/*** Created by huangyj on 2018/5/24.*/ public class TargetImp implements Target{@Overridepublic boolean doing() {System.out.println("執行目標類的具體業務邏輯");return false;} }靜態代理類必須實現和被代理相同的接口。
/*** 代理者* Created by huangyj on 2018/5/24.*/ public class MyProxy implements Target{private Target target;public MyProxy(Target target){super();this.target = target;}@Overridepublic boolean doing() {//前置增強doBefor();//由被調用者執行原生的邏輯boolean falg = target.doing();//后置增強doAfter();return falg;}private void doBefor(){System.out.println("執行前置增強邏輯");}private void doAfter(){System.out.println("執行后置增強邏輯");} }
特點:
? ? 1.解決靜態代理的問題,不需要實現接口,擴展性良好。
? ? 2.沒有具體的代理類,不用生成.class文件,由java的API動態的在內存中生成代理對象。
使用到的java核心API:
? ? 通過Proxy.newProxyInstance(ClassLoader loader,//被代理類的類加載器
????????????????????????????????????????????????????????????Class<?>[] interfaces,//被代理類的接口?????????????????????????InvocationHandler h //實現增強的類)方法來生成代理類 實現InvocationHandler接口的invoke()方法來做增強業務處理。代碼:
import com.tarn.study.proxy.LisonCompany;import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; /*** 動態代理實現* Created by huangyj on 2018/5/25.*/ public class DynamicProxy {/*** 獲取代理類* @param target* @return 動態生成的代理類*/public static Object proxy(Object target) {return Proxy.newProxyInstance(target.getClass().getClassLoader(),target.getClass().getInterfaces(), new MyInvocationHanlder(target));}/*** 用于實現增強的類*/private static class MyInvocationHanlder implements InvocationHandler {//需要被增強的類private Object target;public MyInvocationHanlder(Object target) {super();this.target = target;}@Overridepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable {//前置增強doBefor();//原來服務Object res = method.invoke(target, args);//后置增強doAfter();return res;}public void doBefor() {System.out.println("前置增強業務......");}public void doAfter() {System.out.println("后置增強業務......");}} }
- 需要引入cglib的jar包。spring-core-3.2.5.jar(spring的核心包中已經包含了Cglib的功能,所以用這個就可以了)
- cglib是在在內存中動態構建子類,所以也屬于動態代理。
- 目標對象的方法如果為final/static,那么就不會被攔截,即不會執行目標對象額外的業務方法.
總結
以上是生活随笔為你收集整理的java代理模式学习笔记的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 入门级node+uni-app开发即时通
- 下一篇: 码云上开源JAVA项目收藏