AOP(Aspect Oriented Programming)是什么?

部署运行你感兴趣的模型镜像

AOP是什么?

板桥里人 http://www.jdon.com 2004/01/09
为什么要区分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概念进行分析,和大家一起学习进步。

您可能感兴趣的与本文相关的镜像

GPT-oss:20b

GPT-oss:20b

图文对话
Gpt-oss

GPT OSS 是OpenAI 推出的重量级开放模型,面向强推理、智能体任务以及多样化开发场景

<think>首先,用户的问题是:"Aspect Oriented Programming(AOP)从某种意义上说是对OOP的补充。什么是AOP,什么是OOP?" 我需要用中文回答这个问题。 关键点: - **OOP (Object-Oriented Programming)**: 面向对象编程。这是一种编程范式,基于“对象”的概念,对象包含数据(属性)和方法(函数)。核心概念包括封装、继承和多态。 - **AOP (Aspect-Oriented Programming)**: 面向切面编程。这是一种编程范式,用于处理横切关注点(cross-cutting concerns),如日志记录、事务管理、安全性等,这些功能通常跨越多个对象或模块。AOP 允许将这些关注点模块化为“切面”,从而减少代码重复和耦合。 用户提到AOP是对OOP的补充,所以我需要解释两者之间的关系:AOP 解决了OOP中难以模块化的横切关注点问题,从而补充了OOP的不足。 回答结构: 1. 定义OOP:简要解释什么是面向对象编程。 2. 定义AOP:解释什么是面向切面编程。 3. 解释补充关系:说明AOP如何补充OOP,特别是在处理横切关注点方面。 4. 提供示例:用简单的代码或场景说明两者的区别和结合。 由于规则要求,在回答后必须提出3-5个相关问题,并以“§§相关问题§§”开头,禁止换行分散。相关问题应基于用户的问题和我的回答。 相关问题想法: 1. AOP的主要优势是什么? 2. 在Spring框架中,AOP是如何实现的? 3. OOP和AOP的主要区别是什么? 4. 横切关注点有哪些常见例子? 5. 如何在实际项目中使用AOP来改进代码质量? 确保回答完整,最后输出相关问题。 最终回答格式: - 先回答用户问题。 - 然后以“§§相关问题§§”开头,列出3-5个相关问题。</think>### 什么是OOP? **OOP(面向对象编程)** 是一种编程范式,核心是通过“对象”组织代码。对象包含: - **属性**:数据状态(如 `class User { private String name; }`) - **方法**:操作行为(如 `public void login() { ... }`) 关键特性: 1. **封装**:隐藏内部细节(如 `private` 字段 + `public` 方法) 2. **继承**:子类复用父类逻辑(如 `class Admin extends User`) 3. **多态**:同一接口不同实现(如 `Animal a = new Dog(); a.sound()`) 4. **抽象**:定义接口忽略实现细节(如 `interface Payment { void pay(); }`) 目标:提升代码复用性、可维护性,模拟现实世界实体。 ### 什么是AOP? **AOP(面向切面编程)** 是一种补充OOP的编程范式,专注于**横切关注点(Cross-Cutting Concerns)**——即跨越多个对象的公共功能(如日志、事务、安全)。核心思想: - **切面(Aspect)**:模块化横切逻辑(如日志记录器) - **连接点(Join Point)**:程序执行点(如方法调用) - **通知(Advice)**:切面在连接点的行为(如方法执行前记录日志) - **切入点(Pointcut)**:定义哪些连接点应用通知(如 `@Pointcut("execution(* com.service.*.*(..))")`) 示例(Spring AOP): ```java @Aspect @Component public class LoggingAspect { // 定义切入点:拦截所有Service层方法 @Pointcut("execution(* com.example.service.*.*(..))") public void serviceMethods() {} // 前置通知:在方法执行前记录 @Before("serviceMethods()") public void logMethodCall(JoinPoint joinPoint) { System.out.println("调用方法: " + joinPoint.getSignature().getName()); } } ``` ### 为什么AOP是对OOP的补充? - **OOP的局限**: 横切关注点(如日志)会散落在多个类中,导致**代码重复**(如每个方法都写日志)和**耦合度高**(业务逻辑与非核心功能混合)。 - **AOP的解决方案**: 通过切面**解耦横切关注点**,使业务类(如 `UserService`)只关注核心逻辑,而日志、事务等由切面统一管理。 例如: - OOP 中:每个方法需手动调用日志工具类 - AOP 中:通过切面自动织入日志,业务代码保持简洁 **总结**: OOP 垂直划分系统(按对象职责),AOP 水平划分系统(按功能维度),两者结合实现**高内聚、低耦合**的代码结构。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值