亚洲一级免费看,特黄特色大片免费观看播放器,777毛片,久久久久国产一区二区三区四区,欧美三级一区二区,国产精品一区二区久久久久,人人澡人人草

JAVA認證

Java動態(tài)代理的解析

時間:2024-11-03 09:37:23 JAVA認證 我要投稿
  • 相關推薦

關于Java動態(tài)代理的解析

  動態(tài)代理類是位于Java.lang.reflect包下的Interface InvocationHandler。下面小編準備了關于Java動態(tài)代理的解析,提供給大家參考!

  眾所周知,JDK的動態(tài)代理模式必須實現(xiàn)接口。

  以下面的源碼為例:

  接口一:

  public interface ActionInterface {

  void doSelf(String str);

  String getType();

  }

  接口二:

  public interface InterruupIntf {

  void interrup();

  }

  實現(xiàn)類:

  public class MyselfImpl implements ActionInterface, InterruupIntf {

  public String getType() {

  String type = "公用部門";

  System.out.println(type);

  return type;

  }

  public void doSelf(String str) {

  System.out.println("業(yè)務實現(xiàn)類: " + str + " !");

  }

  public void interrup() {

  System.out.println("發(fā)呆三分鐘!");

  }

  }

  動態(tài)代理需要反射,

  * 必須要實現(xiàn)InvocationHandler接口

  * 能夠對所有的方法進行代理

  public class MyInvocationHandler implements InvocationHandler {

  private Object obj;

  /**

  * 通過構造方法來設置被代理的對象

  * @param obj

  */

  public MyInvocationHandler(Object obj) {

  this.obj = obj;

  }

  /**

  * 動態(tài)代理需要反射

  *

  */

  public Object invoke(Object proxy, Method method, Object[] args)

  throws Throwable {

  System.out.println("+++++++++++調用業(yè)務方法之前做其他事情");

  Object returnObject = method.invoke(obj, args);

  System.out.println("+++++++++++調用業(yè)務方法之前做其他事情");

  return returnObject;

  }

  /**

  * 測試函數(shù)

  * 動態(tài)代理對所有的代理類都進行了攔截

  * @throws NoSuchMethodException

  * @throws InvocationTargetException

  * @throws IllegalAccessException

  * @throws InstantiationException

  * @throws SecurityException

  * @throws IllegalArgumentException

  */

  public static void main(String[] args) throws InterruptedException,

  IllegalArgumentException, SecurityException,

  InstantiationException, IllegalAccessException,

  InvocationTargetException, NoSuchMethodException {

  //實現(xiàn)業(yè)務邏輯的類

  MyselfImpl muSelf = new MyselfImpl();

  //JDK創(chuàng)建的動態(tài)邏輯類,調用上面的構造函數(shù)注入

  MyInvocationHandler myInvocation = new MyInvocationHandler(muSelf);

  /*

  Class proxyClass = Proxy.getProxyClass(

  MyselfImpl.class.getClassLoader(), MyselfImpl.class.getInterfaces());

  //建業(yè)務邏輯類的動態(tài)代理類

  Object proxy = proxyClass.getConstructor(

  new Class[] { InvocationHandler.class }).newInstance(

  new MyInvocationHandler(new MyselfImpl())); */

  //建業(yè)務邏輯類的動態(tài)代理類

  Object proxy = Proxy.newProxyInstance(MyselfImpl.class.getClassLoader(), MyselfImpl.class.getInterfaces(), myInvocation);

  //業(yè)務類自己調用運行代理對象

  ActionInterface testIntf = (ActionInterface) proxy;

  testIntf.doSelf("我要做業(yè)務了!");

  testIntf.getType();

  InterruupIntf intIntf = (InterruupIntf) proxy;

  intIntf.interrup();

  }

  }

  運行最后一個類的MAIN函數(shù),控制臺輸出結果如下:

  +++++++++++調用業(yè)務方法之前做其他事情

  業(yè)務實現(xiàn)類: 我要做業(yè)務了! !

  +++++++++++調用業(yè)務方法之前做其他事情

  +++++++++++調用業(yè)務方法之前做其他事情

  公用部門

  +++++++++++調用業(yè)務方法之前做其他事情

  +++++++++++調用業(yè)務方法之前做其他事情

  發(fā)呆三分鐘!

  +++++++++++調用業(yè)務方法之前做其他事情

  看到結果了。

  JDK的動態(tài)代理,對MyselfImpl所有方法都進行了攔截,在調用真正的業(yè)務類方法之前之后都插入了代碼,這就是JDK的動態(tài)代理。其實SPRING的AOP思想的基本原理也是這個,但是它寫的比較負責,而且比較優(yōu)秀。

【Java動態(tài)代理的解析】相關文章:

java命令行參數(shù)解析201606-02

計算機二級JAVA考點解析08-08

Java與Java web的區(qū)別08-22

JAVA認證基礎知識:基于反射機制的服務代理調用07-18

Java與Java web有什么不同01-22

新動態(tài)國際英語09-13

excel動態(tài)表格制作09-01

新加坡留學的動態(tài)分析08-09

2017土地登記代理人《理論與方法》模擬題及答案解析09-02

留學法國的新動態(tài)06-23