Spring使用 --- 基本概念(二):AOP,面向方面编程

本文讲述sprint的第二个基本概念: AOP,即面向方面编程

什么是面向方面编程

软件项目中,日志系统等服务系统被核心功能系统调用,日志系统的代码分散在各处。面向方面编程将日志等服务系统独立出来,作为单独一个模块,形成一个“方面”。然后通过一些手段将日志与核心代码再联系起来,叫做“织入”。由此将原来混杂在一起的代码分离成单独的模块,代码质量提高,模块内聚性更高,核心模块专注于处理核心业务流程,而不需要关注不相关的东西,如记录日志、考虑安全等因素。

通过面向方面编程,模块可以更加独立。只要不是本模块需要做的事情,都可以抽取成为一个“方面”,形成一个新的类。

几个核心概念:

  1. 通知: 定义“什么”及“何时”。 “什么”表示这个通知要做什么事情(可以理解成一个函数),“何时”表示这个通知在什么时候被触发。根据“何时”,可将通知分为5种:前置通知、后置通知、返回通知、异常通知、环绕通知。
  2. 切点: 定义“何处”,表示通知在什么地方被调用。在spring中,都是在函数被调用时调用,因此切点具体定义在哪个包的哪个函数,返回值是何类型、输入参数旭什么类型的函数。
  3. 切面(或方面): 切面是通知和切点的集合

以上例子中,日志系统就是一个切面,切面中的某个函数是通知,并且可以通过配置指定在“何时”,并且将核心系统中的哪个类的哪个方法作为切点,这个通知被触发。

Sprint只支持在普通函数被调用时的AOP,不支持成员变量被修改时、或构造函数被调用时的AOP。因为Spring实现AOP的方式是通过动态的为核心系统类生成一个代理对象来实现的。但这可覆盖大多数的需求。

怎样使用

待补充。

什么时候使用

在设计一个类时,考虑某个功能时,问一个问题:这个功能是不是必须要我来做,或者由我来做是否合理。如果不是,则都可以将这个功能抽取出来作为一个切面。

当需要为一个类增加功能时。

当要修改一个类的功能时。

好处

  • 更加精细的类划分,类更容易重用
  • 模块更加内聚,只关心自己确实需要做的事务,不相关的事务都可以提取为一个切面独立出来
  • 可以在不修改类定义的情况下,给类增加功能、修改功能

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java架构

详解Proxy代理模式的场景分析

1847
来自专栏Java架构

详解Proxy代理模式的场景分析

代理模式是一个十分优秀的软件架构模式,许多应用都用到了代理模式。代理模式就是为其他对象提供一种代理以控制对这个对象的访问。在某些情况下,一个对象不合适或者不能直...

2084
来自专栏java达人

Kafka漫游记

我是一条消息,从我被生产者发布到topic的时候,我就清楚自己的使命:被消费者获取消费。但我一直很纳闷,把我直接推送给消费者不就行了,为什么一定要先推送到类似队...

2397
来自专栏Java职业技术分享

分布式 | Dubbo 架构设计详解

Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合(或者最大限度地松耦合)。从服务模型的角度...

2100
来自专栏菩提树下的杨过

动软.net代码生成器 win2008 r2下无法连接oracle,以及vs2008模板丢失的解决

一天之内遇到了二个奇怪的问题,人品值最近有所下降啊。 1、动软.Net代码生成器(就是园子里李天平的大作) 在win2008 r2下无法连接oracle数据库,...

2165
来自专栏杨建荣的学习笔记

Greenplum集群问题修复案例

我看了下GP Master端,看到负载并不高,当然这是一个初步的检测,如果集群响应缓慢,则很可能是segment节点上出现了延迟。一看则吓一跳,这是一个segm...

1002
来自专栏F-Stack的专栏

用DPDK rte_ring实现多进程间通信

F-Stack是多进程架构,去除了进程间资源共享来达到更高的性能,但还是有部分控制信息需要在进程间同步,使用rte_ring让多个进程间的通信变得十分简单。 r...

6667
来自专栏源码之家

清空TMP文件夹下的文件

1333
来自专栏blackpiglet

如何在单节点 Ceph 中配置多数据副本

在服务器资源不足,或者测试环境下,Ceph 通常只有一个节点,就算有多个服务器组成集群,往往存储服务器也往往只有一台,Ceph 的默认配置下,只能设置单数据备份...

1463
来自专栏Java架构师学习

详解Proxy代理模式的场景分析

1968

扫码关注云+社区