为什么要区分J2EE容器和J2EE应用系统?
我们知道,J2EE应用系统只有部署在J2EE容器中才能运行,那么为什么划分为J2EE容器和J2EE应用系统? 通过对J2EE容器运
行机制的分析,我们可以发现:实际上J2EE容器分离了一般应用系统的一些通用功能,例如事务机制、安全机制以及对象池或线程池等性能优化机制。
这些功能机制是每个应用系统几乎都需要的,因此可以从具体应用系统中分离出来,形成一个通用的框架平台,而且,这些功能机制的设计开发有一定难度,同时运行的稳定性和快速性都非常重要,必须经过长时间调试和运行经验积累而成,因此,形成了专门的J2EE容器服务器产品,如Tomcat JBoss、Websphere、WebLogic等。
从J2EE系统划分为J2EE容器和J2EE应用系统两个方面,我们已经看到一种分散关注的思路(separation of concerns)。
分散关注
将通用需求功能从不相关类之中分离出来;同时,能够使得很多类共享一个行为,一旦行为发生变化,不必修改很多类,只要修改这个行为就可以。
AOP就是这种实现分散关注的编程方法,它将“关注”封装在“方面”中。
AOP是什么?
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的父类,将无法方便实现。重用被打折扣,具体访问类因为也包含“锁”状态之类的相关代码,只能被重用在相关有“锁”的场合,重用范围很窄。
仔细研究这个应用的“锁”,它其实有下列特性:
“锁”功能不是具体访问类的首要或主要功能,访问类主要功能是访问数据对象,例如读取数据或更改动作。
“锁”行为其实是和具体访问类的主要功能可以独立、区分开来的。
“锁”功能其实是这个系统的一个纵向切面,涉及许多类、许多类的方法。如下图:
因此,一个新的程序结构应该是关注系统的纵向切面,例如这个应用的“锁”功能,这个新的程序结构就是aspect(方面)在这个应用中,“锁”方面(aspect)应该有以下职责:
提供一些必备的功能,对被访问对象实现
加锁或解锁功能。以保证所有在修改数据对象的操作之前能够调用lock()加锁,在它使用完成后,调用unlock()解锁。
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服务器
基于字节码的项目有:
aspectwerkz
spring
分享到:
相关推荐
【留言公告管理系统J2EE】是一个基于Java企业级平台(J2EE)开发的应用程序,主要用于管理和展示公告以及处理用户留言。系统的核心功能是提供一个交互式的平台,使得信息能够及时、有效地在用户和管理员之间传递。...
J2EE(Java 2 Platform, Enterprise Edition)是一个用于构建企业级应用的Java平台,它提供了丰富的服务和组件模型,包括Web容器、EJB(Enterprise JavaBeans)容器、JMS(Java Message Service)、JTA(Java ...
本系统采用Java企业版(J2EE)技术进行开发,旨在提供一个功能完善的、区分普通用户和管理员权限的学生信息管理平台。下面将详细介绍J2EE框架下学生管理系统的实现细节。 J2EE(Java 2 Platform, Enterprise ...
在基于J2EE的开发中,Action类是Struts 2框架的核心组件,它负责接收用户的请求,处理业务...完成这个实验项目,你将具备使用Struts 2框架进行J2EE开发的基本能力,为进一步学习和实践企业级Web应用打下坚实的基础。
在传统的RBAC模型基础上,本文进一步扩展了模型,增加了组织结构、业务流程和应用分类等概念。这些扩展有助于更准确地定义角色及其权限,同时提高了系统的可配置性和灵活性。例如,组织结构可以帮助区分不同部门之间...
在IT行业中,J2EE(Java 2 Platform, Enterprise Edition)是一种用于开发企业级应用程序的框架,它由Oracle公司提供并被广泛应用于构建分布式、多层的Web应用程序。J2EE培训通常涵盖了一系列技术,包括Struts和...
容器对于组件来说是一个抽象层,它屏蔽了操作系统和硬件的差异,为组件提供了一个统一的运行环境。 接下来,中间件作为独立的系统软件或服务程序,其作用是在不同的技术之间共享资源,管理计算资源和网络通信。它...
J2EE知识大全 通过本篇文章,我们将对J2EE的核心知识进行详细的介绍,使初学者快速掌握J2EE编程的基础知识。 html基本知识点: * html是超文本标记语言,主要用于编写网页 * html中的基本元素是标记,标记的格式...
XML 部署描述文件是 J2EE application 的一个组件,用于描述应用程序的结构和部署信息。 2. Java EE 技术框架可分为三部分:组件技术、(服务技术)、通信技术。服务技术是指提供给组件的公共服务,例如事务管理、...
- **为什么需要事务**:为了保证数据操作的原子性、一致性、隔离性和持久性。 - **什么是事务**:一组操作要么全部成功,要么全部失败。 - **事务的边界划分**:定义事务开始和结束的位置。 - **声明型事务的...
它提供了一个以服务器为中心的多层应用体系结构,为企业应用系统提供了高度可移植性和兼容性的平台。J2EE的多层体系结构显著简化了开发、配置和维护企业应用的过程。该平台将企业的业务逻辑与用户接口分开,并放置在...
**J2EE Tutorial Translation** 是一份详尽的Java 企业版(J2EE)学习教程,专门为想要深入了解和掌握J2EE技术的开发者设计。这份文档不仅提供了理论知识,还附带了源代码,使学习者能够通过实践来加深理解。 J2EE...
在JSP页面转换为Servlet的过程中,Web容器会自动调用与之对应的标记处理程序来处理这些自定义标记。自定义标记的主要目标是减少JSP页面的代码量,提高可维护性,尤其适合处理重复的、特定于应用程序的业务逻辑。 ...
Web容器是实现J2EE规范中Web层协议的软件环境,主要负责管理Web组件(如Servlets和JSPs)的生命周期、并发控制、安全性以及与Web服务器的交互。它提供了必要的基础设施,使得Web组件能够高效地处理客户端请求。 **6...
用户管理是几乎所有应用系统中必不可少的一部分。本研究通过用户管理模块来阐述如何在Struts、Hibernate和Spring的轻型J2EE架构中实现分层设计。 1. **域模型设计**:在设计用户管理模块时,首先定义了不同类型的...
- **异常处理**:理解异常处理机制,能够正确使用try-catch-finally语句块,并能够区分编译时异常和运行时异常。 #### 二、EJB(Enterprise JavaBeans) - **EJB分类**:了解Session Beans、Entity Beans和Message-...
Log4j是Apache软件基金会开发的一个开源日志框架,广泛应用于JSP(JavaServer Pages)和J2EE(Java 2 Platform, Enterprise Edition)应用程序中。本文将深入探讨Log4j在错误处理中的应用及其重要性。 首先,Log4j...
- **分布式多层应用程序**:强调 J2EE 支持构建复杂的分布式系统。 - **J2EE 容器**:容器负责管理组件生命周期和服务,如 EJB 容器、Web 容器等。 - **打包 J2EE 组件**:介绍如何将组件打包成 WAR 或 EAR 文件...