AspectJ的一个简单例子
AspectJ是一个特定于java语言的面向方面编程语言。官方网站是?http://www.eclipse.org/aspectj/。
AspectJ已经很成熟,并且有一个成熟的编辑工具:AJDT(eclipse插件)
?
下面介绍一个AspectJ的简单例子,从而对AspectJ有一个直观的认识:
?
在面向对象语言中,我们一般用一个类处理一个关注点的需求。
但是在很多情况下,类不仅要处理自己的关注点,还必须满足另一个关注点的需求。
也就是说类被系统中的多个关注点横切了.
在类中多种关注点的混合将会导致代码分散和代码纠缠的发生。
代码分散是指处理一个关注点所需的代码会分散到处理其他关注点的类中。
代码纠缠是指利用一个类或方法实现了系统中的多个关注点。
?
下面是一个People类:
?
?
public class People {private String name;private int age;public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}}?
这个类实现了系统中People数据对象的类模型。我们把它称为主要关注点。
但是现在出现了一个新的需求,就是对所有People对象的属性访问都要记录日志。
即一个次要关注点(横切关注点):对所有People对象的属性访问都要记录日志。
下面是将次要关注点直接编码到People类的代码:
?
?
public class People {private String name;private int age;public String getName() {return name;}public void setName(String name) {System.out.println(">>> Log : modify people's attribute ...");this.name = name;}public int getAge() {return age;}public void setAge(int age) {System.out.println(">>> Log : modify people's attribute ...");this.age = age;}}?虽然People类实现了日志功能,不过日志关注点的代码分散到了实现People类模型的代码中(代码分散),而且People
类实现了多个关注点(代码纠缠)。这样对代码的修改于维护都是很不利的。
现在我们利用AspectJ来将这两个关注点分离。下面是AspectJ代码:
?
?
public aspect PeopleAspect {pointcut setXXX():call(public void People.set*(*));before():setXXX(){System.out.println(">>> Log : modify people's attribute ...");}}?
利用AspectJ编译器编译AspectJ程序和第一个People类(即将AspectJ程序织入到第一个People类中),
然后运行下面的主程序测试:
?
?
public static void main(String[] args){People p = new People();p.setAge(24);p.setName("Tom");}?控制台输出如下:
?
?
???>>> Log : modify people's attribute ...
???>>> Log : modify people's attribute ...
?
我们发现同样实现了日志功能,而且程序结构更加清晰。
AspectJ的语法类似于Java的语法,不过有一些特殊的关键字,关于它的更多内容请参见AspectJ官方文档。
?
?