当前位置:googles上网导航 ->> 信息广场 ->> 应用大全 ->> Java大全 ->> 正文

AspectJ中的around advice的学习


http://www.googles.com.cn 时间:2005-8-7 17:23:00 来源:互联网络

Around:将连接点的执行旁路到Around()的语句中,如果要在执行Around()后继续执行连接点的内容,需要在Around()中加入关键字processed()

如下面代码所示:

我们有一个类HelloTestHelloTest中有一个方法sayHello(),功能只是在trace窗口打印一个“Hello AspectJ!”的语句。

 

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();

       }

}

 

我们再创建一个方面LogAspect,定义一个pointcut write,来捕捉所有的类成员函数(除了LogAspect的函数和所有的公共静态函数)。为这个pointcut加上一个around advice,让被捕捉的连接点执行时通知LogAspect执行around()

 

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");

       }

}

 

运行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!

around()的作用,可以用来做数据检验,错误处理等。
关闭窗口

【 相 关 内 容 】

热点内容

最近更新