afrag  
          記錄學(xué)習(xí)和成長的歷程
          日歷
          <2005年11月>
          303112345
          6789101112
          13141516171819
          20212223242526
          27282930123
          45678910
          統(tǒng)計
          • 隨筆 - 9
          • 文章 - 5
          • 評論 - 2
          • 引用 - 0

          導(dǎo)航

          常用鏈接

          留言簿

          隨筆分類

          隨筆檔案

          文章檔案

          搜索

          •  

          積分與排名

          • 積分 - 10227
          • 排名 - 2373

          最新評論

          閱讀排行榜

          評論排行榜

           

          在Spring 的AOP中,如果一個Proxy同時實現(xiàn)MethodBeforeAdvice、AfterReturningAdvice和MethodInterceptor接口,那么這三個Advice的執(zhí)行順序是什么樣的呢?
          經(jīng)過試驗,是和xml文件中的定義順序有關(guān)的。
          如果Proxy的接口實現(xiàn)定義為
          ?????
          ?????????
          ??????????? MethodBeforeAdvice
          ??????????? AfterReturningAdvice
          ??????????? MethodInterceptor
          ?????????

          ?????

          那么執(zhí)行的結(jié)果是
          MethodBeforeAdvice

          MethodInterceptor: before call

          Really method excuting

          MethodInterceptor: after call

          AfterReturningAdvice

          也就是說,執(zhí)行順序是:MethodBeforeAdvice,MethodInterceptor的調(diào)用前的部分,目標(biāo)方法,MethodInterceptor的調(diào)用后的部分,AfterReturningAdvice。

          如果proxy的定義是
          ?????
          ?????????
          ??????????? MethodBeforeAdvice
          ??????????? MethodInterceptor
          ??????????? AfterReturningAdvice
          ?????????

          ?????

          執(zhí)行的結(jié)果是
          MethodBeforeAdvice

          MethodInterceptor: before call

          Really method excuting

          AfterReturningAdvice

          MethodInterceptor: after call
          也就是說,執(zhí)行的順序是:MethodBeforeAdvice,MethodInterceptor的調(diào)用前的部分,目標(biāo)方法,AfterReturningAdvice,MethodInterceptor的調(diào)用后的部分。

          如果proxy的定義是
          ?????
          ?????????
          ??????????? MethodInterceptor
          ??????????? MethodBeforeAdvice
          ??????????? AfterReturningAdvice
          ?????????

          ?????

          執(zhí)行的結(jié)果是:
          MethodInterceptor: before call

          MethodBeforeAdvice

          Really method excuting

          AfterReturningAdvice

          MethodInterceptor: after call
          也就是說,執(zhí)行的順序是:MethodInterceptor的調(diào)用前的部分,MethodBeforeAdvice,目標(biāo)方法,AfterReturningAdvice,MethodInterceptor的調(diào)用后的部分。
          以上的順序是在springframework 1.2.5中測試的。

          posted on 2005-11-02 18:10 afrag 閱讀(3723) 評論(1)  編輯  收藏 所屬分類: Java隨想
          評論:
          • # re: Spring AOP中MethodBeforeAdvice、AfterReturningAdvice和MethodInterceptor的執(zhí)行順序  jadmin Posted @ 2009-08-29 00:33
            是這樣的嗎?  回復(fù)  更多評論   

           
          Copyright © afrag Powered by: 博客園 模板提供:滬江博客
          主站蜘蛛池模板: 财经| 阿克陶县| 昌吉市| 临夏市| 临沭县| 东城区| 连江县| 平山县| 扶余县| 丽水市| 长丰县| 恩平市| 叙永县| 永顺县| 古丈县| 吴川市| 南雄市| 莒南县| 利津县| 溧阳市| 紫阳县| 吴川市| 大石桥市| 大化| 信宜市| 永吉县| 阳春市| 沈阳市| 潼南县| 山西省| 洛阳市| 沙河市| 垦利县| 稻城县| 屏边| 滨海县| 宁都县| 兴安县| 勐海县| 紫阳县| 布拖县|