AspectJ中的around advice的学习

Around:将连接点的执行旁路到Around()的语句中,如果要在执行Around()后继续执行连接点的内容,需要在Around()中加入关键字processed()
如下面代码所示:
我们有一个类HelloTest,HelloTest中有一个方法sayHello(),功能只是在trace窗口打印一个“Hello AspectJ!”的语句。
<!--[if !supportEmptyParas]--> <!--[endif]-->
public class HelloTest {
       private Logger logger = Logger.getLogger("trace");
       public void sayHello(){
              logger.logp(Level.INFO, "HelloTest","sayHello", "Hello AspectJ!");
       }
      
       public static void main(String[] args) {
              HelloTest ht = new HelloTest();
              ht.sayHello();
       }
}
<!--[if !supportEmptyParas]--> <!--[endif]-->
我们再创建一个方面LogAspect,定义一个pointcut write,来捕捉所有的类成员函数(除了LogAspect的函数和所有的公共静态函数)。为这个pointcut加上一个around advice,让被捕捉的连接点执行时通知LogAspect执行around()。
<!--[if !supportEmptyParas]--> <!--[endif]-->
public aspect LogAspect {
       private Logger logger = Logger.getLogger("trace");
       public pointcut write(): execution(* *.*(..)) && !within(LogAspect) && !execution(public static * *.*(..));
       void around():write(){
              Signature sig = thisJoinPointStaticPart.getSignature();
              logger.logp(Level.INFO, sig.getDeclaringType().getName(),
              sig.getName(), "processing");
       }
}
<!--[if !supportEmptyParas]--> <!--[endif]-->
运行HelloTest,在控制台将显示:
2005-7-5 22:25:13 com.cxl.taj.HelloTest sayHello
信息: processing
在上面的around()中添加processed(),如下所示
void around():write(){
              Signature sig = thisJoinPointStaticPart.getSignature();
              logger.logp(Level.INFO, sig.getDeclaringType().getName(),
              sig.getName(), "processing");
              processed();
       }
运行HelloTest,在控制台将显示:
2005-7-5 22:27:35 com.cxl.taj.HelloTest sayHello
信息: processing
2005-7-5 22:27:35 HelloTest sayHello
信息: Hello AspectJ!
在执行完around()后,系统将执行sayHello()中的代码。
void around():write(){
              processed();
              Signature sig = thisJoinPointStaticPart.getSignature();
              logger.logp(Level.INFO, sig.getDeclaringType().getName(),
              sig.getName(), "processing");
       }
如果将processed()的位置改在around()的开头,运行结果将变成:
2005-7-5 22:30:15 HelloTest sayHello
信息: Hello AspectJ!
2005-7-5 22:30:15 com.cxl.taj.HelloTest sayHello
信息: processing
在执行around()中的logp()前,sayHello()将被先执行。
可见processed()就是将连接点的代码执行一次。从下面的例子可以看得更明白。
void around():write(){
              proceed();
              Signature sig = thisJoinPointStaticPart.getSignature();
              logger.logp(Level.INFO, sig.getDeclaringType().getName(),
              sig.getName(), "processing");
              proceed();
       }
结果将是:
2005-7-5 22:31:27 HelloTest sayHello
信息: Hello AspectJ!
2005-7-5 22:31:27 com.cxl.taj.HelloTest sayHello
信息: processing
2005-7-5 22:31:27 HelloTest sayHello
信息: Hello AspectJ!
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值