为什么要区分J2EE容器和J2EE应用系统?
我们知道,J2EE应用系统只有部署在J2EE容器中才能运行,那么为什么划分为J2EE容器和J2EE应用系统? 通过对J2EE容器运行机制的分析,我们可以发现:实际上J2EE容器分离了一般应用系统的一些通用功能,例如事务机制、安全机制以及对象池或线程池等性能优化机制。
这些功能机制是每个应用系统几乎都需要的,因此可以从具体应用系统中分离出来,形成一个通用的框架平台,而且,这些功能机制的设计开发有一定难度,同时运行的稳定性和快速性都非常重要,必须经过长时间调试和运行经验积累而成,因此,形成了专门的J2EE容器服务器产品,如Tomcat JBoss、Websphere、WebLogic等。
从J2EE系统划分为J2EE容器和J2EE应用系统两个方面,我们已经看到一种分散关注的思路(separation of concerns)。
分散关注
将通用需求功能从不相关类之中分离出来;同时,能够使得很多类共享一个行为,一旦行为发生变化,不必修改很多类,只要修改这个行为就可以。
AOP就是这种实现分散关注的编程方法,它将“关注”封装在“方面”中。
AOP是什么?
网管网www_bitscn_com
AOP是OOP的延续,是Aspect Oriented Programming的缩写,意思是面向方面编程。AOP实际是GoF设计模式的延续,设计模式孜孜不倦追求的是调用者和被调用者之间的解耦,AOP可以说也是这种目标的一种实现。
举例:假设有在一个应用系统中,有一个共享的数据必须被并发同时访问,首先,将这个数据封装在数据对象中,称为Data Class,同时,将有多个访问类,专门用于在同一时刻访问这同一个数据对象。
为了完成上述并发访问同一资源的功能,需要引入锁Lock的概念,也就是说,某个时刻,当有一个访问类访问这个数据对象时,这个数据对象必须上锁Locked,用完后就立即解锁unLocked,再供其它访问类访问。
使用传统的编程习惯,我们会创建一个抽象类,所有的访问类继承这个抽象父类,如下:
abstract class Worker{
abstract void locked();
abstract void accessDataObject();
abstract void unlocked();
}
缺点:
accessDataObject()方法需要有“锁”状态之类的相关代码。Java只提供了单继承,因此具体访问类只能继承这个父类,如果具体访问类还要继承其它父类,比如另外一个如Worker的父类,将无法方便实现。重用被打折扣,具体访问类因为也包含“锁”状态之类的相关代码,只能被重用在相关有“锁”的场合,重用范围很窄。 网管u家www.bitscn.net
仔细研究这个应用的“锁”,它其实有下列特性:
“锁”功能不是具体访问类的首要或主要功能,访问类主要功能是访问数据对象,例如读取数据或更改动作。
“锁”行为其实是和具体访问类的主要功能可以独立、区分开来的。
“锁”功能其实是这个系统的一个纵向切面,涉及许多类、许多类的方法。如下图:
因此,一个新的程序结构应该是关注系统的纵向切面,例如这个应用的“锁”功能,这个新的程序结构就是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
网管u家www.bitscn.net
记录跟踪 优化 校准
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. 有近十年历史,技术成熟。
网管bitscn_com
缺点:过于复杂;破坏封装;需要专门的Java编译器。
动态AOP:使用JDK的动态代理API或字节码Bytecode处理技术。
基于动态代理API的具体项目有:
JBoss 4.0 JBoss 4.0服务器
nanning
基于字节码的项目有:
aspectwerkz
spring ? 【转自www.bitsCN.com】
分享到:
相关推荐
通过深入理解Spring AOP的这些核心概念和实践步骤,开发者可以更加高效地利用AOP实现关注点分离,提高代码的可维护性和可扩展性。同时,Spring AOP的灵活性使其能够在不同的应用场景中发挥作用,是Java高级编程中不...
AOP的核心概念包括: 1. **通知(Advice)**:通知定义了切面在何时何地执行。在Spring中,有五种不同类型的Advice:`Before`(前置通知)、`After-Returning`(返回后通知)、`After-Throwing`(异常后通知)、`...
《深入解析aopalliance源码》 在Java开发领域,AOP(Aspect Oriented Programming,面向切面编程)作为一种重要的编程范式,为解决模块化编程中的横切关注点问题提供了新的思路。AOPalliance是AOP框架之间的一个...
《Spring AOP 源码系列:ProxyFactoryBean》 在深入探讨Spring AOP(面向切面编程)的实现机制时,ProxyFactoryBean是至关重要的一个组件。它扮演着生成代理对象的角色,使得我们能够在不修改原有代码的情况下,对...
Spring AOP(面向切面编程)是Spring框架的重要组成部分,它提供了一种模块化和解耦的编程方式,使得我们可以在不修改业务代码的情况下,实现对应用程序中的关键行为进行拦截和增强。在"springaop+arg"这个主题中,...
### AOP概念详解 #### 一、AOP概述 面向切面编程(Aspect-Oriented Programming,简称AOP)是一种编程范式,旨在通过将横切关注点与业务逻辑分离,增强代码的可读性和可维护性。在企业级应用中,事务管理、日志...
在 Spring AOP 中,主要有两个概念:Aspect 和 Advice。Aspect 是一个模块,它封装了一个或者多个 Advice。Advice 是一个函数,它提供了某种特殊的功能,例如日志记录、安全检查等。Spring AOP 通过 Aspect 和 ...
一、理解AOP概念 AOP的核心思想是将分散在各个模块中的交叉性代码(如日志、事务处理)抽取出来,形成独立的切面,以便于复用和维护。它提供了一种模块化的方式,使得我们可以专注于编写核心业务代码,而无需关心...
在实际开发中,`spring-aop.xsd`的使用通常涉及到以下几个核心概念: 1. 切面(Aspect):封装一组相关或相互关联的横切关注点的模块。 2. 通知(Advice):在特定连接点上执行的代码,如前置通知、后置通知、环绕...
### 一、AOP 概念解析 **1.1 AOP 的定义** AOP (Aspect Oriented Programming) 即面向切面编程,是一种编程范式,它允许程序员将横切关注点(Cross-cutting Concerns)模块化。在 Spring 框架中,AOP 主要用于实现...
**SPRING AOP 概念解析以及例子示范** 在Java开发中,Spring框架因其强大的功能和灵活的设计,被广泛应用于企业级应用。其中,AOP(Aspect Oriented Programming,面向切面编程)是Spring框架的一个重要特性,它...
AOP Alliance 定义了一系列接口,用于实现上述的核心概念: - **`org.aopalliance.intercept.MethodInterceptor`**:表示环绕通知的接口,其中的 `invoke` 方法会在目标方法执行前后被调用。 - **`org.aopalliance....
**一、AOP概念解析** 1. **切面(Aspect)**:一个关注点的模块化,例如事务管理就是一个切面。在Spring AOP中,切面由`@Aspect`注解的类定义。 2. **连接点(Join Point)**:程序执行过程中的某个特定点,如方法...
Spring AOP,全称Spring面向切面编程,是一种强大的设计模式,它允许程序员在不修改原有代码的情况下,插入额外的功能,比如日志记录、性能监控、安全控制等。AOP的核心概念包括通知(Advice)、连接点(Joinpoint)...
首先,我们需要知道Spring AOP的核心概念——切面(Aspect)、通知(Advice)、连接点(Join Point)、切入点(Pointcut)和代理(Proxy)。切面是封装了特定关注点的模块,如日志或事务管理。通知是在特定连接点...
在AOP方面,它包含了Spring的AOP模块,提供了声明式通知、代理创建、切点表达式解析等功能。通过这个库,开发者可以定义切面、通知(advice)、切点(pointcut)等核心概念,并使用Spring的自动代理机制将这些切面织...
而aopalliance-1.0.jar是实现这一目标的关键组件之一。这个库是AOP联盟(AOP Alliance)的一个产品,它提供了一组公共接口,使得不同的AOP框架可以互相协作,从而在各种AOP实现之间保持兼容性。 AOP联盟是一个开源...
在Java开发领域,Spring框架是广泛应用的开源框架之一,它为开发者提供了许多强大的功能,其中包括面向切面编程(Aspect-Oriented Programming,简称AOP)。本文将深入探讨Spring AOP的配置及其在模拟MVC模式下的...