`
leiliang
  • 浏览: 45731 次
社区版块
存档分类
最新评论

AOP(Aspect Oriented Programming)是什么(转)

阅读更多
为什么要区分J2EE容器和J2EE应用系统?
    我们知道,J2EE应用系统只有部署在J2EE容器中才能运行,那么为什么划分为J2EE容器和J2EE应用系统? 通过对J2EE容器运行机制的分析(见我的电子教材“EJB实用原理”),我们可以发现:实际上J2EE容器分离了一般应用系统的一些通用功能,例如事务机制、安全机制以及对象池或线程池等性能优化机制。
  这些功能机制是每个应用系统几乎都需要的,因此可以从具体应用系统中分离出来,形成一个通用的框架平台,而且,这些功能机制的设计开发有一定难度,同时运行的稳定性和快速性都非常重要,必须经过长时间调试和运行经验积累而成,因此,形成了专门的J2EE容器服务器产品,如Tomcat JBoss、Websphere、WebLogic等。
  从J2EE系统划分为J2EE容器和J2EE应用系统两个方面,我们已经看到一种分散关注的思路(separation of concerns)。

分散关注
    将通用需求功能从不相关类之中分离出来;同时,能够使得很多类共享一个行为,一旦行为发生变化,不必修改很多类,只要修改这个行为就可以。

   AOP就是这种实现分散关注的编程方法,它将“关注”封装在“方面”中。

AOP是什么?
    AOP是OOP的延续,是Aspect Oriented Programming的缩写,意思是面向方面编程。
  举例:假设有在一个应用系统中,有一个共享的数据必须被并发同时访问,首先,将这个数据封装在数据对象中,称为Data Class,同时,将有多个访问类,专门用于在同一时刻访问这同一个数据对象。
  为了完成上述并发访问同一资源的功能,需要引入锁Lock的概念,也就是说,某个时刻,当有一个访问类访问这个数据对象时,这个数据对象必须上锁Locked,用完后就立即解锁unLocked,再供其它访问类访问。
  使用传统的编程习惯,我们会创建一个抽象类,所有的访问类继承这个抽象父类,如下:
abstract class Worker{
  abstract void locked();
  abstract void accessDataObject();
  abstract void unlocked();
}

缺点:
  • accessDataObject()方法需要有“锁”状态之类的相关代码。
  • Java只提供了单继承,因此具体访问类只能继承这个父类,如果具体访问类还要继承其它父类,比如另外一个如Worker的父类,将无法方便实现。
  • 重用被打折扣,具体访问类因为也包含“锁”状态之类的相关代码,只能被重用在相关有“锁”的场合,重用范围很窄。

仔细研究这个应用的“锁”,它其实有下列特性:
  • “锁”功能不是具体访问类的首要或主要功能,访问类主要功能是访问数据对象,例如读取数据或更改动作。
  • “锁”行为其实是和具体访问类的主要功能可以独立、区分开来的。
  • “锁”功能其实是这个系统的一个纵向切面,涉及许多类、许多类的方法。如下图:




   
    因此,一个新的程序结构应该是关注系统的纵向切面,例如这个应用的“锁”功能,这个新的程序结构就是aspect(方面)
  在这个应用中,“锁”方面(aspect)应该有以下职责:
  提供一些必备的功能,对被访问对象实现加锁或解锁功能。以保证所有在修改数据对象的操作之前能够调用lock()加锁,在它使用完成后,调用unlock()解锁。
AOP应用范围
    很明显,AOP非常适合开发J2EE容器服务器,目前JBoss 4.0正是使用AOP框架进行开发。
  具体功能如下:
  • Authentication 权限
  • Caching 缓存
  • Context passing 内容传递
  • Error handling 错误处理
  • Lazy loading 懒加载
  • Debugging  调试
  • logging, tracing, profiling and monitoring 记录跟踪 优化 校准
  • Performance optimization 性能优化
  • Persistence  持久化
  • Resource pooling 资源池
  • Synchronization 同步
  • Transactions 事务


AOP有必要吗?
    当然,上述应用范例在没有使用AOP情况下,也得到了解决,例如JBoss 3.XXX也提供了上述应用功能,但是没有使用AOP。
  但是,使用AOP可以让我们从一个更高的抽象概念来理解软件系统,AOP也许提供一种有价值的工具。可以这么说:因为使用AOP结构,现在JBoss 4.0的源码要比JBoss 3.X容易理解多了,这对于一个大型复杂系统来说是非常重要的。
  从另外一个方面说,好像不是所有的人都需要关心AOP,它可能是一种架构设计的选择,如果选择J2EE系统,AOP关注的上述通用方面都已经被J2EE容器实现了,J2EE应用系统开发者可能需要更多地关注行业应用方面aspect。

AOP具体实现
    AOP是一个概念,并没有设定具体语言的实现,它能克服那些只有单继承特性语言的缺点(如Java),目前AOP具体实现有以下几个项目:
    AspectJ (TM): 创建于Xerox PARC. 有近十年历史,成熟

  缺点:过于复杂;破坏封装;需要专门的Java编译器。

  动态AOP:使用JDK的动态代理API或字节码Bytecode处理技术。
  基于动态代理API的具体项目有:
    JBoss 4.0 JBoss 4.0服务器
    nanning这是以中国南宁命名的一个项目,搞不清楚为什么和中国相关?是中国人发起的?

  基于字节码的项目有:
    aspectwerkz
    springframework

在以后其它文章中,我将继续对AOP概念进行分析,和大家一起学习进步。
  • 大小: 7.3 KB
分享到:
评论

相关推荐

    Aspect-Oriented Programming with AspectJ

    AOP(Aspect-Oriented Programming)的核心思想是将应用程序中的关注点分离为独立的模块,称为方面(Aspects)。这有助于提高代码的可读性、可维护性和重用性。在面向对象编程中,横切关注点往往分散在多个类和方法...

    Aspect-Oriented Programming

    ### 面向切面编程(Aspect-Oriented Programming, AOP) #### 一、概述 面向切面编程(Aspect-Oriented Programming, AOP)是一种编程范式,旨在提高程序模块化程度,通过分离关注点(Separation of Concerns, SoC...

    Spring 2.5 Aspect-Oriented Programming source code

    Spring 2.5 是 Spring 框架的一个重要版本,它在面向切面编程(Aspect-Oriented Programming,AOP)方面提供了强大的支持。面向切面编程是一种编程范式,旨在将关注点分离,使代码更加模块化,尤其是处理那些跨越多...

    Aspect-Oriented Programming 面向方面编程

    Aspect-Oriented Programming 面向方面编程 简称AOP AOP所要做的事情就是从系统中分离出方面,然后集中实现,从面可以独立编写业务逻辑代码,在系统运行的时候,再将方面代码“织入”到系统中

    Eclipse AspectJ: Aspect-Oriented Programming

    Aspect-oriented software design (ASOD), which follows the Java philosophy of "write once, run anywhere", is a new way of thinking about program construction. It is a rapidly growing and evolving ...

    aop:aspect

    标题 "aop:aspect" 指涉的是Spring框架中的面向切面编程(Aspect-Oriented Programming, AOP)的一个核心概念。在Spring AOP中,`aop:aspect`是XML配置中定义一个切面的元素,它允许我们将关注点(如日志、事务管理...

    Aspect Oriented Programming的简写,中文通常译作面向方面编程,其核心内容就是所谓的“横切关注点”

    面向方面编程(Aspect Oriented Programming,AOP)是一种编程范式,旨在提高代码的模块化程度,通过将程序中的关注点分离,使代码更易于维护和扩展。在传统的面向对象编程(OOP)中,关注点通常是混合在一起的,...

    Spring 2.5 Aspect-Oriented Programming

    为了解决这些问题,面向切面编程(Aspect-Oriented Programming, AOP)应运而生。 #### 面向切面编程的定义与作用 面向切面编程是一种旨在补充面向对象编程而非替代它的编程范式。它帮助开发者创建更为清晰和结构...

    AOP - Mastering AspectJ Aspect-Oriented Programming in Java(John Wiley and Sons).pdf

    ### AOP - Mastering AspectJ Aspect-Oriented Programming in Java #### 核心知识点解析 **一、面向切面编程(Aspect-Oriented Programming, AOP)简介** 面向切面编程是一种编程范式,旨在提高模块化程度,通过...

    Spring 2.5 aspect oriented programming

    This book is written for software architects, engineers, and developers that want be able to write applications in a more modular and concise way, without learning Aspect or using languages other than...

    Aspect-Oriented Programming in JAVA

    面向切面编程(Aspect-Oriented Programming,简称AOP)是一种在Java等编程语言中用于解决横切关注点(cross-cutting concerns)的编程范式。传统的面向对象编程(Object-Oriented Programming,OOP)虽然强大且广泛...

    MeSDK-delphi Aspect Programming

    The MeAOP Library is Aspect Oriented Programming for delphi. IMO, the aspect is the general feature in fact. It's a helper for object-oriented programming to re-use the feature(function), such as the...

    aspect.js-JavaScript library for aspect-oriented programming usi

    在JavaScript开发中,面向切面编程(Aspect-Oriented Programming,AOP)是一种将关注点分离的技术,它允许开发者将横切关注点(如日志、事务管理、性能监控等)从核心业务逻辑中解耦出来。aspect.js是一个...

    Aspect-Oriented Programming with C# and .NET

    ### 面向方面的编程(Aspect-Oriented Programming, AOP)在C#与.NET中的应用 #### 概述 面向方面的编程(AOP)是一种编程范式,它旨在提高程序模块化,通过将横切关注点(cross-cutting concerns)从业务逻辑中...

    Spring AOP基础关于AOP是什么的理解

    AOP(Aspect Oriented Programming 面向方面的编程)是一种实现横切面的工具,它是 OOP 的补充,而不是 OOP 的竞争对手。AOP 的出现是为了解决 OOP 中的缺陷,即 OOP 中的类封装了自己所必须的业务逻辑,导致类之间...

    AOP(面向切面)的C#例子VS2012

    AOP为Aspect Oriented Programming的缩写,意为:面向切面编程(也叫面向方面),可以通过预编译方式和运行期动态代理实现在不修改源代码的情况下给程序动态统一添加功能的一种技术。AOP实际是GoF设计模式的延续,...

    AOP.in..NET

    AOP in .NET: Practical Aspect-Oriented Programming 296 pages Publisher: Manning Publications; Pap/Psc edition (June 25, 2013) Language: English ISBN-10: 1617291145 ISBN-13: 978-1617291142 ...

    aop介绍

    AOP(Aspect Oriented Programming)介绍 AOP 是 OOP 的延续,是 Aspect Oriented Programming 的缩写,意思是面向方面编程。AOP 实际是 GoF 设计模式的延续,设计模式孜孜不倦追求的是调用者和被调用者之间的解耦...

Global site tag (gtag.js) - Google Analytics