丄諦啲仇魜ヤ
如 果 敌 人 让 你 生 气 , 那 说 明 你 没 有 胜 他 的 把 握!
posts - 6,comments - 56,trackbacks - 1

AOP全名为Aspect-Oriented Programming,有关于AOP的许多名词术语都过于抽象,单从字面上并不容易理解其名词意义,这边将以之前介绍代理机制的范例来逐一对照以介绍AOP的术语与观念:

  • <!--[if !supportLists]-->Cross-cutting concern

DynamicProxyDemo项目的例子中,记录的动作原先被横切(Cross-cutting)入至HelloSpeaker本身所负责的业务流程之中,另外类似于记录这类的动作,如安全(Security)检查、事务(Transaction)等系统层面的服务(Service),在一些应用程序之中常被见到安插至各个对象的处理流程之中,这些动作在AOP的术语中被称之为Cross-cutting concerns
 

以图片说明可强调出Cross-cutting concerns的意涵,例如原来的业务流程是很单纯的:



现在为了要加入记录(Logging)与安全(Security)检查等服务,对象的程序代码中若被硬生生的写入相关的LoggingSecurity程序片段,则可使用以下图解表示出Cross-cuttingCross-cutting concerns的概念:



Cross-cutting concerns若直接撰写在负责某业务的对象之流程中,会使得维护程序的成本增高,例如若您今天要将对象中的记录功能修改或是移除该服务,则必须修改所有撰写曾记录服务的程序代码,然后重新编译,另一方面,Cross-cutting concerns混杂于业务逻辑之中,使得业务对象本身的逻辑或程序的撰写更为复杂。

  •   <!--[endif]-->Aspect

将散落于各个业务对象之中的Cross-cutting concerns收集起来,设计各个独立可重用的对象,这些对象称之为Aspect,例如在DynamicProxyDemo项目中将登录的动作设计为一个LogHandler类别,LogHandler类别在AOP的术语就是Aspect的一个具体实例,在AOP中着重于Aspect的辨认,将之从业务流程中独立出来,在需要该服务的时候,缝合(Weave至应用程序之上,不需要服务的时候,也可以马上从应用程序中脱离,应用程序中的可重用组件不用作任何的修改,例如在DynamicProxyDemo项目中的HelloSpeaker所代表的角色就是应用程序中可重用的组件,在它需要记录服务时并不用修改本身的程序代码。

另一方面,对于应用程序中可重用的组件来说,以AOP的设计方式,它不用知道处理提供服务的对象之存在,具体的说,与服务相关的API不会出现在可重用的应用程序组件之中,因而可提高这些组件的重用性,您可以将这些组件应用至其它的应用程序之中,而不会因为目前加入了某些服务而与目前的应用程序框架发生耦合。

  • <!--[if !supportLists]-->Advice

Aspect的具体实作称之为Advice,以记录的动作而言,Advice中会包括真正的记录程序代码是如何实作的,像是DynamicProxyDemo项目中的LogHandler类别就是Advice的一个具体实例,Advice中包括了Cross-cutting concerns的行为或所要提供的服务。 

  • <!--[if !supportLists]-->Joinpoint

Aspect在应用程序执行时加入业务流程的点或时机称之为Joinpoint,具体来说,就是Advice在应用程序中被呼叫执行的时机,这个时机可能是某个方法被呼叫之前或之后(或两者都有),或是某个例外发生的时候。

  • <!--[if !supportLists]--><!--[endif]-->Pointcut

Pointcut是一个定义,藉由这个定义您可以指定某个Aspect在哪些Joinpoint时被应用至应用程序之上。具体的说,您可以在某个定义档中撰写Pointcut,当中说明了哪些Aspect要应用至应用程序中的哪些Joinpoint 

  • <!--[if !supportLists]-->Target

一个Advice被应用的对象或目标对象,例如DynamicProxyDemo项目中的HelloSpeaker就是LogHandler这个AdviceTarget

  • <!--[if !supportLists]--><!--[endif]-->Introduction

对于一个现存的类别,Introduction可以为其增加行为,而不用修改该类别的程序,具体的说,您可以为某个已撰写、编译完成的类别,在执行时期动态加入一些方法或行为,而不用修改或新增任何一行程序代码。

  • <!--[if !supportLists]--><!--[endif]-->Proxy

Expert One-on-One J2EE Development WIthout EJB一书中,Rod JohnsonJuergen Hoeller在第八章中有提到,AOP的实作有五个主要的策略:Dynamic ProxiesDynamic Byte Code GenerationJava Code GenerationUse of a Custon Class LoaderLanguage Extensions

在之前静态代理与动态代理中,已经使用实际的程序范例介绍过代理机制的实现,SpringAOP主要是透过动态代理来完成。

  • <!--[if !supportLists]-->Weave

Advice被应用至对象之上的过程称之为缝合(Weave),在AOP中缝合的方式有几个时间点:编译时期(Compile time)、类别加载时期(Classload time)、执行时期(Runtime)。
 

结合DynamicProxyDemo的实例,将以上介绍过的AOP相关名词具体的使用图片来加以表示,有助于您对每一个名词的理解与认识:

posted on 2007-09-13 19:33 Crying 阅读(353) 评论(2)  编辑  收藏 所属分类: spring

FeedBack:
# re: AOP观念(转载)
2007-09-16 11:07 | Crying
IOC 个人理解
从字面意思来说是控制反转,利用依赖注入模式将原来组件依赖于对象的关系,改变成组件依赖于抽象接口,将应用程序依赖于容器变成容器管理应用程序。为了调用IOC容器,组件必须利用BeanFactory或ApplicationContext,利用他们可以管理容器中的Bean实例的生命周期,用getBean(String ...)方法得到Bean实例,ApplicationContext在BeanFactory的基础之上实现了扩展增加了资源取得,消息解析,事件处理等功能,使得Spring的IOC容器来协调各组件间相互的依赖关系。
http://www.itisedu.com/phrase/200603091205485.html



  回复  更多评论
  
# re: AOP观念(转载)
2007-09-16 11:50 | Crying
AOP对我来说到现在还没真正的理解,昨天晚上又把《Spring开发 手册》和《精通Spring》的AOP部分看了哈可是还是云里雾里的,要是叫我说出AOP的思想我肯定打哽心里是明白会用,可就是说不上来(丢人了....).。
我现在就把我所能说的都说出来啊,说的不对大家别骂我,要是能对AOP有很好理解的麻烦给我留个言,给小弟带来点感悟。。。先谢谢啦。
我认为AOP的实现其实就是靠的就是代理Bean(PoxyFactoryBean)和拦截器(Interceptor)来实现的。
AOP中有几个关键字Aspect,advice,pointCut,target,......
Aspect 就是将你想往目标对象中插入的东西(如事务,日志),将这些日志,事务封装成一个类也就成了Aspect了。
advice 是可是说是Aspect中的一个方法吧。
pointCut 是目标对象中的一个方法,也就是你想在目标对像的哪个位置织入你 的Advice。
target 就是你的目标对象啦

Spring AOP  回复  更多评论
  

只有注册用户登录后才能发表评论。


网站导航: