AspectJ中的around advice的学习
来源:互联网 发布:数据资源管理 编辑:程序博客网 时间:2024/05/16 19:51
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!
- AspectJ中的around advice的学习
- AspectJ之Advice定义之Around advice
- AspectJ学习笔记之Advice
- Spring AOP @Before @Around @After 等 advice 的执行顺序
- Spring AOP @Before @Around @After 等 advice 的执行顺序
- Spring AOP @Before @Around @After 等 advice 的执行顺序
- Spring AOP @Before @Around @After 等 advice 的执行顺序
- Spring AOP 中 advice 的四种类型 before after throwing advice around
- Spring AOP 中 advice 的四种类型 before after throwing advice around
- spring AOP 中 advice 的四种类型 before after throwing advice around
- AspectJ之 Advice扩展
- Spring.NET sample -> Around Advice
- AspectJ之Advice定义之Before Advice
- AspectJ之Advice定义之finally advice
- 关于对Spring中AOP的Advice(通知、增强)的属性Around的理解
- aspectJ的学习总结
- AspectJ之Advice定义之After returning advice
- AspectJ之Advice定义之After throwing advice
- 7月9日 出生的人!这个就是我吗?
- 从临时表返回数据时遇到的问题(ORA-08103: object no longer exists)
- Microsoft Visual Studio 2005中使用水晶报表
- 自己写的数据库基类(VB.NET_WinForm)
- MySQL数据库的导入和导出
- AspectJ中的around advice的学习
- linux 终端下命令失效
- TCP/IP网络重复型服务器通信软件设计
- 写得蛮好的linux学习笔记
- 如何取得IP/用户名等信息
- 如何反转一个单链表 How to reverse a singly linked list
- 详细注解ASPJPGE组件的添加水印用法
- 如何对框架和MADC进行打包部署
- C# 插件构架实战