Spring理论基础-面向切面编程
AOP是Aspect-Oriented Programming的缩写,中文翻译是面向切面编程。作为Spring的特征之一,是要好好学习的。
首先面向切面编程这个名称很容易让人想起面向对象编程(OOP)来。我们知道面向对象编程是从上往下的把系统拆分成若干个类,如Web项目中常见的Controller、Service、Dao等分层。但是面向对象编程对于从左到右的水平抽象十分无力,类似于日志、权限等系统级功能的代码会重复的出现在任何地方。简单的说,面向切面编程是对面向对象编程的一种补充,它可以把系统里一些分散的重复代码集中在一起,抽象成一个切面。先来举一个例子:
有一个内部使用的管理系统,Controller中的每个接口在调用时都要记录下当前用户名称、当前时间等参数。
很明显这个需求的实现代码在每个接口中都是重复的。即使提取成公共类的公共方法,在每个接口里也都有一句该公共方法的调用,导致类之间的耦合。
我们希望把原来接口中的记录代码去除掉,使这些接口只关注自己的业务逻辑。然后使用预编译或运行期动态代理等方式实现在不修改接口代码的情况下,为接口添加记录功能。这种动态地将代码织入到类的指定方法、指定位置上的编程思想就是面向切面编程。
概念
面向切面编程具体的一些概念。
《EXPERT ONE ON ONE J2EE DEVELOPMENT WITHOUT EJB》第8章、《Spring实战》第4章:
增强(advice,另译为通知,但《Spring3.x企业应用开发实战》作者不赞成):在特定连接点执行的动作。例子中的实现代码就是增强。
切点(pointcut):一组连接点的总称,用于指定某个增强应该在何时被调用。例子中的指定哪些接口和指定位置就是切点。
连接点(join point):在应用执行过程中能够插入切面的一个点。例子中具体的一个接口和指定位置的结合就是连接点。
切面(aspect):通知(即增强)和切点的结合。
AOP在Spring中主要是通过动态代理实现的,具体实现也分为两种:JDK动态代理和CGLIB动态代理。其中JDK动态代理是基于接口代理,CGLIB动态代理是基于继承代理。
JDK动态代理
作为Java自带的一种动态代理技术,JDK动态代理的优势是使用反射技术来生成代理类,在生成效率上比较高。缺点是只能基于接口来动态代理,如果目标类没有实现任何接口是不能使用JDK动态代理的。
来看一个用JDK动态代理的例子。
public class DynamicProxy implements InvocationHandler {
/**
* 被代理类
*/
private Object target;
public DynamicProxy(Object target) {
this.target = target;
}
public static Object bind(Object target) {
InvocationHandler invocationHandler = new DynamicProxy(target);
return Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), invocationHandler);
}
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println(method.getName() + " 方法执行前");
//执行被代理类方法
Object ret = method.invoke(target, args);
System.out.println(method.getName() + " 方法执行后");
return ret;
}
public static void main(String[] args) {
Dao dao = new OrderDao();
dao.doSomeThing();
Dao daoProxy = (Dao) DynamicProxy.bind(dao);
daoProxy.doSomeThing();
}
}
复制代码
public class OrderDao implements Dao {
@Override
public void doSomeThing() {
System.out.println("test");
}
}
复制代码
public interface Dao {
void doSomeThing();
}
复制代码
输出:
test
doSomeThing 方法执行前
test
doSomeThing 方法执行后
Process finished with exit code 0
复制代码
后记
这次只是梳理下概念,把自己理解的AOP概念写下来。也参考了很多文章,大体都是一致的细节上有些不同,把自己理解的写出来给大家看下就知道有没有错了。顺便整理一下,免得以后别人问起自己支支吾吾的不知道从哪说起。并没有去了解Spring中具体的AOP实现,有兴趣的同学可以自行深入了解下。
Spring理论基础-面向切面编程的更多相关文章
- Spring(4)——面向切面编程(AOP模块)
Spring AOP 简介 如果说 IoC 是 Spring 的核心,那么面向切面编程就是 Spring 最为重要的功能之一了,在数据库事务中切面编程被广泛使用. AOP 即 Aspect Orien ...
- Spring IOP 面向切面编程
Spring IOP 面向切面编程 AOP操作术语 Joinpoint(连接点):所谓连接点是指那些被拦截到的点.在spring中,这些点指的是方法,因为spring只支持方法类型的连接点.(类里面 ...
- 利用例子来理解spring的面向切面编程
最近学习了spring的面向切面编程,在网上看到猴子偷桃的例子,觉得这种方式学习比书本上讲解有趣多了,也便于理解.现在就来基于猴子偷桃写个基本的例子. maven工程:
- 详细解读 Spring AOP 面向切面编程(二)
本文是<详细解读 Spring AOP 面向切面编程(一)>的续集. 在上篇中,我们从写死代码,到使用代理:从编程式 Spring AOP 到声明式 Spring AOP.一切都朝着简单实 ...
- spring AOP面向切面编程学习笔记
一.面向切面编程简介: 在调用某些类的方法时,要在方法执行前或后进行预处理或后处理:预处理或后处理的操作被封装在另一个类中.如图中,UserService类在执行addUser()或updateUse ...
- 【Spring系列】Spring AOP面向切面编程
前言 接上一篇文章,在上午中使用了切面做防重复控制,本文着重介绍切面AOP. 在开发中,有一些功能行为是通用的,比如.日志管理.安全和事务,它们有一个共同点就是分布于应用中的多处,这种功能被称为横切关 ...
- 从源码入手,一文带你读懂Spring AOP面向切面编程
之前<零基础带你看Spring源码--IOC控制反转>详细讲了Spring容器的初始化和加载的原理,后面<你真的完全了解Java动态代理吗?看这篇就够了>介绍了下JDK的动态代 ...
- Spring AOP面向切面编程详解
前言 AOP即面向切面编程,是一种编程思想,OOP的延续.在程序开发中主要用来解决一些系统层面上的问题,比如日志,事务,权限等等.在阅读本文前希望您已经对Spring有一定的了解 注:在能对代码进行添 ...
- Spring AOP 面向切面编程相关注解
Aspect Oriented Programming 面向切面编程 在Spring中使用这些面向切面相关的注解可以结合使用aspectJ,aspectJ是专门搞动态代理技术的,所以比较专业. ...
随机推荐
- JSON解析与序列化
JSON之所以流行,拥有与JavaScript类似的语法并不是全部原因.更重要的一个原因是,可以把JSON数据结构解析为有用的 JavaScript对象.与XML数据结构要解析成DOM文档而且从中提取 ...
- JDK源码分析 – ArrayList
ArrayList类的申明 ArrayList是一个支持泛型的,底层通过数组实现的一个可以存任意类型的数据结构,源码中的定义如下: public class ArrayList<E> ex ...
- JavaScript数组自定义属性
我们可以以json键值对的形式自定义属性. 首先定义一个JS数组JSarray. 然后按json键值对的形式进行赋值. 最后在控制台显示结果. 代码如下: var JSarray = new Arra ...
- WPF实例,以getFiles()获取文件夹,treeview的应用
读取电脑硬盘根目录添加到TreeView控件 foreach (DriveInfo item in System.IO.DriveInfo.GetDrives()) { if(item.ToStrin ...
- echart模块化单文件引入
echart模块化单文件引入百度上面是推荐这样使用.今天看了一下,做了个Demo. 文件结构如下:
- Codeforces Round #469 (Div. 2) F. Curfew
贪心 题目大意,有2个宿管分别从1和n开始检查房间,记录人数不为n的房间个数,然后锁住房间. 没有被锁的房间中的学生可以选择藏在床底,留在原地,或者转移(最远转移d个房间) 然后抄了网上大神的代码 ...
- POJ1741:Tree——题解+树分治简要讲解
http://poj.org/problem?id=1741 题目大意:给一棵树,求点对间距离<=k的个数. ———————————————————— 以这道题为例记录一下对于树分治的理解. 树 ...
- HDU.1285 确定比赛名次 (拓扑排序 TopSort)
HDU.1285 确定比赛名次 (拓扑排序 TopSort) 题意分析 裸的拓扑排序 详解请移步 算法学习 拓扑排序(TopSort) 只不过这道的额外要求是,输出字典序最小的那组解.那么解决方案就是 ...
- 【树状数组】【P2345】 奶牛集会
传送门 Description 约翰的\(N\)头奶牛每年都会参加"哞哞大会".哞哞大会是奶牛界的盛事.集会上的活动很多,比如堆干草,跨栅栏,摸牛仔的屁股等等.它们参加活动时会聚在 ...
- 【队列】【P2827】【NOIP2016D2T3】蚯蚓
传送门 Description 本题中,我们将用符号 $\lfloor c \rfloor$ 表示对 $c$ 向下取整,例如:$\lfloor 3.0 \rfloor = \lfloor 3.1 \r ...