<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    邊城愚人

    如果我不在邊城,我一定是在前往邊城的路上。

      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      31 隨筆 :: 0 文章 :: 96 評論 :: 0 Trackbacks

    ??? ??? target 切入點格式如下: target ([ Type Identifier ])。 Type 指示對連接點處的對象類型提供一個靜態(tài)編譯時評估,并采用完全限定類名的形式(也就是說, Type 不能是使用通配符的類型聲明模式)。 Identifier 提供了一種方法,可通過它來評估連節(jié)點處的運行時對象的實際類型,而不僅僅是靜態(tài)類型。 Identifier 在運行時動態(tài)地賦予合適的對象。

    ??? ??? 下面通過例子說明一下 target 的使用:

    public interface Animal {

    ??? void speak();

    }


    public class Cat implements Animal{

    ??? public void speak() {

    ??? ??? System. out .println( " 喵喵 " );

    ??? }

    }


    public class Dog implements Animal{

    ??? public void speak() {

    ??? ??? System. out .println( " 汪汪 " );

    ??? }

    }

    public class Zoo {

    ??? private List<Animal> animals = new ArrayList<Animal>();

    ??? public void addAnimal(Animal a){

    ??? ??? animals .add(a);

    ??? }

    ??? public void speak(){

    ??? ??? for (Animal a : animals ){

    ??? ??? ??? ??? a.speak();

    ??? ??? }

    ??? }

    }

    ???

    定義一個切入點如下:

    public pointcut speakCallOne():

    ??? call (* speak()) && target (Animal);

    ??? ??? 雖然 pointcut speakCallOne() 中的 call (* speak()) 匹配所有類的 speak() 方法(這里匹配 Cat Dog Zoo ),但 target (Animal) 便將 pointcut speakCallOne() 限定在 Animal 及其子類(也就是 Cat Dog ,而不包含 Zoo )。這里當然可以使用 call (* Animal.speak()) 來代替 target 。和靜態(tài)的類型聲明不同, target 并不能靜態(tài)地確定的每一個連接點,因為匹配是基于運行時的類型信息。在使用 AJDT 的情況下,可以看到 target 和靜態(tài)的類型聲明的不同:

    ??? ?? 1)使用靜態(tài)的類型聲明的圖示:

    Screenshot3.png


    Screenshot4.png


    ??? ?? 可以看到,在方面AspectDemo中,before通知的左面有一個向上的小箭頭表示其為通知,而Zoo中的void speak()方法中a.speak();一行的左面有個向右的小箭頭,表明其匹配了一個通知(也就是AspectDemo中的before通知)。
    ??? ?? 2)
    使用target的圖示:

    Screenshot1.png

    Screenshot2.png

    ??? ?? 和靜態(tài)的類型聲明不同,使用了target的before前的箭頭上有個問號,以表明target動態(tài)的不確定性。而Zoo的main中調用的方法z.speak()前有個類似于speak()中的a.speak();的箭頭,不同的是,z.speak()前的箭頭上有個問號,這表明此處speak()并不確定是否匹配通知(因為target是動態(tài)確定連接點)。而實際上情況是,z.speak()確實不是通知的連接點。

    ??? ??? 對于targetIdentifier)的使用,示例如下:

    ??? publicpointcut speakCallTwo(Object o):

    ??? ??? call(* Animal.speak()) && target(o);

    ??? ??? before(Object o):speakCallTwo(o){

    ??? ??? ??? ??? System.out.println(o.getClass());

    ??? ??? }

    ??? }

    ??? ??? 通過將 target付給 Object o,可以在before通知中調用 o的一些操作。

    ??? ??? thistarget指示符的一個補充,它的格式與target相同。在含義上,this表示切入點所匹配的方法的調用類,而target表示匹配方法的目標類。例如:

    ??? ??? publicpointcut anotherSpeakCall():

    ??? ??? ??? call(* speak()) && target(Animal) && this(Zoo);

    ??? ??? target(Animal) 表示void speak()方法是Animal及子類的,它不會匹配 Zoovoid speak()方法。而this(Zoo)會匹配調用了Animal及子類的void speak()方法的 Zoo類的方法,這里就是Zoovoid speak()方法。

    ??? ??? 如上便是關于targetthis的基本用法。該文參考了《Eclipse AspectJ》和《AspectJ cookbook》。

    posted on 2007-07-09 09:17 kafka0102 閱讀(2708) 評論(3)  編輯  收藏 所屬分類: AOP

    評論

    # re: AspectJ學習(2)使用切入點 target和this 2008-05-09 08:32 davide520
    謝謝博主.  回復  更多評論
      

    # re: AspectJ學習(2)使用切入點 target和this[未登錄] 2008-11-01 09:42 piggy
    不錯,受益了.  回復  更多評論
      

    # re: AspectJ學習(2)使用切入點 target和this[未登錄] 2011-03-16 13:12 max
    target() and this() work only for non-static methods  回復  更多評論
      

    主站蜘蛛池模板: 青娱乐在线视频免费观看| 亚洲日产乱码一二三区别| 一区二区3区免费视频| 国产成人免费手机在线观看视频 | 免费看www视频| 亚洲中文字幕无码av在线| 亚洲一级毛片免费在线观看| 亚洲欧洲精品视频在线观看| 手机在线看永久av片免费| 亚洲宅男精品一区在线观看| 永久免费av无码网站韩国毛片 | 美女18毛片免费视频| 国产资源免费观看| 色偷偷尼玛图亚洲综合| 免费精品国产自产拍观看| 人体大胆做受免费视频| 亚洲真人无码永久在线| 免费福利电影在线观看| 亚洲视频在线观看视频| 天天摸天天操免费播放小视频| 亚洲精品国产综合久久久久紧 | 久久国产精品免费看| 亚洲精品熟女国产| 久久不见久久见中文字幕免费| 亚洲欧美日韩中文字幕在线一区| 国产日产成人免费视频在线观看| 日韩精品视频在线观看免费| 国产亚洲日韩在线三区| 97在线视频免费播放| 亚洲精品无码人妻无码| 亚洲精品乱码久久久久久蜜桃| 十八禁视频在线观看免费无码无遮挡骂过 | 亚洲av永久无码一区二区三区 | 久久激情亚洲精品无码?V| 国产午夜精品免费一区二区三区| 亚洲色图古典武侠| 日韩中文无码有码免费视频 | 亚洲深深色噜噜狠狠爱网站| 中国人xxxxx69免费视频| 国产精品亚洲av色欲三区| 最新国产AV无码专区亚洲|