明明白白AOP(傻瓜也会心领神会!)
引子:
AOP(面向方面编程:Aspect Oriented Programing)和IoC一样是Spring容器的内核,声明式事务的功能在此基础上开花结果。但是AOP和OOP差别较大,要很好地理解这个概念,做到心领神会还是不容易的,不过相信看完帖子,你就不再迷惑了。
编程语言最终极的目标就是能以更自然、更灵活的方式模拟世界,从原始机器语言到过程语言再到面向对象的语言,编程语言一步步地用更自然、更灵活的方式描述软件。AOP是软件开发思想发展到一定阶段的产物,但AOP的出现并不是要完全替代OOP,而仅是作为OOP的有益补充。虽然AOP作为一项编程技术已经有多年的历史,但一直长时间停留在学术领域,直到近几年,AOP才作为一项真正的实用技术在应用领域开疆扩土。需要指出的是AOP的应用场合是受限的,它一般只适合于那些具有横切逻辑的应用场合:如性能监测、访问控制、事务管理以及日志记录(虽然有很多文章用日志记录作为讲解AOP的实例,但很多人认为很难用AOP编写实用的程序日志,笔者对此观点非常认同)。不过,这丝毫不影响AOP作为一种新的软件开发思想在软件开发领域所占有的地位。
AOP到底是什么
AOP是Aspect Oriented Programing的简称,最初被译为“面向方面编程”,这个翻译向来为人所诟病,但是由于先入为主的效应,受众广泛,所以这个翻译依然被很多人使用,但我们更倾向于用“面向切面编程”的译法,因为它更加达意。
按照软件重构思想的理念,如果多个类中出现相同的代码,应该考虑定义一个共同的抽象类,将这些相同的代码提取到抽象类中。比如Horse、Pig、Camel这些对象都有run()、eat()的方法,通过引入一个包含这两个方法抽象的Animal父类,Horse、Pig、Camel就可以通过继承Animal复用到run()和eat()的方法。通过引入父类消除多个类中重复代码的方式在大多情况下是可行的,但世界并非永远这样简单,请看下面论坛管理业务类的代码:
代码清单6-1 ForumService
package com.baobaotao.concept;public class ForumService {private TransactionManager transManager;private PerformanceMonitor pmonitor;private TopicDao topicDao;private ForumDao forumDao;public void removeTopic(int topicId) {pmonitor.start();//①-1性能监控开始transManager.beginTransaction();//②-1 事务处理开始topicDao.removeTopic(topicId); //③-1 业务逻辑transManager.commit();//②-1事务处理结束pmonitor.end();//①-2 性能监控结束}public void createForum(Forum forum) {pmonitor.start();//①-1性能监控开始transManager.beginTransaction();//②-1 事务处理开始forumDao.create(forum); //③-2 业务逻辑transManager.commit();//②-1事务处理结束pmonitor.end();//①-2 性能监控结束}…}