在软件业,AOP为AspectOrientedProgramming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续,是软件开发中的一个热点,也是spring框架中的一个重要内容,是函数式编程的一种衍生范型。
如何理解AOP面向切面编程
开始
今天和大家聊聊AOP:面向切面编程思想。开始聊之前,先和大家一起从编程思想的发展说起。
编程思想的发展历程:
1、POP编程
首先,大家应该都知道,什么是POP编程吧,就是面向过程编程。关于这个编程思想就不做介绍了。
从思维上来讲,面向过程更强调细节,忽视了整体性和边界性。
典型代表是C/C++的结构体。
POP的不足:
代码重用性低,不易扩展,维护起来难度大,耦合度比较高。
2、OOP编程
面向对象编程,把事物对象化,对象包含属性和方法,万物皆对象。
当规模不大,面向过程编程就可以了
最终实现业务,还是得面向过程,按照过程,把业务串起来。
OOP的形式:一个模块由多个类组成,模块又组成某个服务,多个服务组成一个系统
业务变更,需要修改代码,类肯定要发生改变
但是类应该是固定的,不应该频繁被修改,甚至是不允许修改
从而引出了设计模式,就是为了解决这个问题。
OOP的思想,对象组织,是以继承关系为主线,纵向的,有底到高。
OOP问题:
1)、共性问题,纵向思维,共性越多,接口就越多
2)、扩展问题,需要对现有的对像动态添加某种行为。
因此,由于OOP的问题,从而引出了AOP编程
3、AOP编程
所谓的AOP:面向切面编程,它是可以通过预编译的方式和运行期动态实现,在不修改源代码的情况下,给程序动态统一添加功能的技术。
OOP是关注将需求功能划分为不同的,相对独立的,封装良好的类,并让他们有自已的行为,依靠继顾,多态来定义彼此的关系。
AOP是希望能够将通用功能从不相关的类分离出来,能够使很多类,共享一个行为,这个行为,一旦发生变化,我们只需要修改这个行为就行了,而不需要去修改其他的类。
AOP的切面怎么理解呢?
橫切关注点:比如一个电商系统,处理一个订单,需要进行授权认证,订单处理,日志记录。。。更多操作;商品入库,也需要进行授权认证,入库处理,日志记录。。。更多操作。
OOP,程序都是通过类和接口组织的,核心业务逻辑采用OOP是很合理的。但对于横跨系统中多个模块的功能需求,就比较吃力了,比如日志处理,授权验证,统一的异常处理,性能统计等
而这些都有一个共同点,都是非业务的,非业务的功能代码,从业务代码中抽离出来,独立到非业务的功能代码中,这样我们改变这些行为时,就不会影响现有的业务逻辑代码
简单来说,AOP就是将通用功能抽取出来。面向切面,就是关注通用功能,而不关注业务,而我们的OOP是关注业务的,这就是它们的区别。
AOP实现原理:预先定义一组特性,使它具有拦截方法的功能,执行方法之前和之后做你想要做的事情,而这个的拦截关卡,就是所谓的切面
过滤器,其实就是AOP的一种实现
AOP的优势:
1)、将通用功能从业务逻中抽离出来,提高代码的复用性,有利于后期的维护和扩展
2)、在软件设计时,抽出通用功能(抽出切面),降低架构的复杂度,这样在做系统时,只需要完成业务处理功能
4、AOP和OOP的区别:
1)、面向的目标不同:OOP面向的是名词领域(商品、对象、类),AOP面向的是动词领域(授权、验证、监控、埋点)
2)、思想结构不同:OOP是纵向结构,AOP是横向结构。
3)、注重的方面不同:OOP注重业务逻辑单元的划分;AOP偏重业务处理过程中某个步骤或者阶段的行为。
5、AOP和OOP的关系。
AOP其实是OOP的一个补充,它们都是编程思想,是相互弥补各自的不足,就犹如,OOP弥补POP的不足。
核心需求,仍然由OOP来实现,具体的业务,由POP来实现。而AOP就是为了让OOP更专注于业务的逻辑处理,它们都是相辅相成的
6、如何在代码里去实现AOP
这里就不过多的介绍了,实现在AOP的方式有很多种,通过设计模式就可以实现。
装饰器模式:允许向一个对象添加新的功能,同时又不改变其结构。
代理模式:一个类代表别一个类,然后向外界提供功能接口。
过滤器。
利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。
上一篇:软件设计:设计模式开篇
下一篇:软件开发——一个学习的过程