AOP面向切面编程

一、概述
  在软件业,AOP意为:面向切面编程,通过预编译方式和运行期间动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续,是软件开发中的一个热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生范型。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。 

1、AOP概念概述

  可以通过预编译方式和运行期动态代理实现在不修改源代码的情况下给程序动态统一添加功能的一种技术。设计模式孜孜不倦追求的是调用者和被调用者之间的解耦,提高代码的灵活性和可扩展性,AOP可以说也是这种目标的一种实现。 

2、AOP思想常应用于以下功能

  日志记录,性能统计,安全控制,事务处理,异常处理等等。将日志记录,性能统计,安全控制,事务处理,异常处理等代码从业务逻辑代码中划分出来,通过对这些行为的分离,我们希望可以将它们独立到非指导业务逻辑的方法中,进而改变这些行为的时候不影响业务逻辑的代码。 

3、AOP/OOP对比分析

  AOP、OOP在字面上虽然非常类似,但却是面向不同领域的两种设计思想,这两种设计思想在目标上有着本质的差异。OOP(面向对象编程)针对业务处理过程的实体及其属性和行为进行抽象封装,以获得更加清晰高效的逻辑单元划分。AOP则是针对业务处理过程中的切面进行提取,它所面对的是处理过程中的某个步骤或阶段,以获得逻辑过程中各部分之间低耦合性的隔离效果。举个简单的例子,对于“雇员”这样一个业务实体进行封装,自然是OOP/OOD的任务,我们可以为其建立一个“Employee”类,并将“雇员”相关的属性和行为封装其中。而用AOP设计思想对“雇员”进行封装将无从谈起。同样,对于“权限检查”这一动作片断进行划分,则是AOP的目标领域。而通过OOD/OOP对一个动作进行封装,则有点不伦不类。换而言之,OOD/OOP面向名词领域,AOP面向动词领域。

4、AOP/OOP关系

  很多人在初次接触 AOP 的时候可能会说,AOP 能做到的,一个定义良好的 OOP 的接口也一样能够做到,我想这个观点是值得商榷的。AOP和定义良好的 OOP 的接口可以说都是用来解决并且实现需求中的横切问题的方法。但是对于 OOP 中的接口来说,它仍然需要我们在相应的模块中去调用该接口中相关的方法,这是 OOP 所无法避免的,并且一旦接口不得不进行修改的时候,所有事情会变得一团糟;AOP 则不会这样,你只需要修改相应的 Aspect,再重新编织(weave)即可。 当然,AOP 也绝对不会代替 OOP。核心的需求仍然会由 OOP 来加以实现,而 AOP 将会和 OOP 整合起来,以此之长,补彼之短。 

5、AOP作用

  面向过程编程离我们已经有些遥远,面向对象编程正主宰着软件世界。当每个新的软件设计师都被要求掌握如何将需求功能转化成一个个类,并且定义它们的数据成员、行为,以及它们之间复杂的关系的时候,面向切面编程为我们带来了新的想法、新的思想、新的模式。如果说面向对象编程是关注将需求功能划分为不同的并且相对独立,封装良好的类,并让它们有着属于自己的行为,依靠继承和多态等来定义彼此的关系的话;那么面向切面编程则是希望能够将通用需求功能从不相关的类当中分离出来,能够使得很多类共享一个行为,一旦发生变化,不必修改很多类,而只需要修改这个行为即可。
  面向切面编程是一个令人兴奋不已的新模式。就开发软件系统而言,它的影响力必将会和有着数十年应用历史的面向对象编程一样巨大。面向切面编程和面向对象编程不但不是互相竞争的技术而且彼此还是很好的互补。面向对象编程主要用于为同一对象层次的公用行为建模。它的弱点是将公共行为应用于多个无关对象模型之间。而这恰恰是面向切面编程适合的地方。有了 AOP,我们可以定义交叉的关系,并将这些关系应用于跨模块的、彼此不同的对象模型。AOP 同时还可以让我们层次化功能性而不是嵌入功能性,从而使得代码有更好的可读性和易于维护。它会和面向对象编程合作得很好。

    我们将代码中的登录判断封装成公共的模块,在需要的地方注入,不需要重复的写登录判断相关的代码。

二、Aop的基本元素

1、Aspect(切面):通常是一个类,里面可以定义切入点和通知

2、Jointpoint(连接点):程序执行过程中明确的点,一般是方法的调用

3、Advice(处理逻辑): AOP在特定的切入点上执行的增强处理
4、pointcut(切点):   带有通知的连接点,在程序中主要体现为书写切入点表达式
5、Introduction:允许添加新的方法和属性到类中。
6、Target(目标类):用于匹配当前目标对象类型的执行方法,其中目标对象持有指定的注解
7、Proxy(代理类):AOP框架创建的对象,代理就是目标对象的加强
8、Weaving(插入):是指应用Aspects到一个Target对象创建Proxy对象的过程:complie time,classload time,runtime
 
三、织入方式

   目前在.NET平台中,支持的织入方式有俩中,一种是静态织入,即编译时织入,另外一个是动态织入,即运行时织入

1、静态织入

  常见的静态织入是PostSharp,但PostSharp是收费版本的,PostSharp的使用可以参考:使用PostSharp在.NET平台上实现AOP

 2、动态织入

  常见的动态织入是使用Castle.DynamicProxy方式,效率相对第一种要慢一点。

原文地址:https://www.cnblogs.com/qtiger/p/13232199.html