AOP概念,原理,应用介绍

心情没法不沉重,被问到AOP是什么?AOP原理是什么?我竟然张大了嘴巴,说不出来!对于一个程序员的打击,还能有比这更大的吗?我没脸说我是个写代码的,我也没脸说我是程序员。

AOP是什么?

定义

AOP,面向切面编程,是对OOP的补充。从网上看到的一句话:这种在运行时,动态的将代码切入到类的指定方法或者指定位置上的编程思想,就是面向切面的编程。这是其中的一种方式,在运行时动态添加。还有另外一种是在编译代码的时候,将代码切入到指定的方法或者位置上去,这是静态添加的方式。

使用

我们在实际的业务中都会有一些公共逻辑,比如日志的记录,事务的管理等等,而如果每次都把日志和事务的代码手动写到业务逻辑前后,重复代码就相当可怕,而如果这些额外代码有修改,必须要每个都修改,这是相当不明智的。AOP可以帮我们解决这些问题。

实现

其实AOP本身并不能帮我们解决那些问题,AOP就是一种思想,而帮我们解决的是具体的AOP的实现,比如aspectj,jboss AOP,以及我们最熟悉的Spring AOP,Spring AOP在Spring1.0的时候是自己实现的AOP框架,在2.0之后就开始集成了aspectj。现在我们所说的Spring AOP就是Spring加Aspectj这种方式。

AOP的相关概念

对于AOP中相关的概念,我们接触更多的还是Spring AOP,这里主要是以Spring AOP的概念来说明:

  • Aspect,切面,一个关注点的模块化,这个关注点可能会横切多个对象。
  • JoinPoint,连接点,在程序执行过程中某个特定的点,比如某方法调用的时候或者处理异常的时候。在Spring AOP中,一个连接点总是表示一个方法的执行。
  • Advice,通知,在切面的某个特定的连接点上执行的动作。
  • Pointcut,切点,匹配连接点的断言。通知和一个切入点表达式关联,并在满足这个切入点的连接点上运行(例如,当执行某个特定名称的方法时)。切入点表达式如何和连接点匹配是AOP的核心:Spring缺省使用AspectJ切入点语法。

上面是关于AOP中几个基本概念的定义,下面看下有关我们使用时的一些概念:

  • Target Object,目标对象,被一个或者多个切面所通知的对象。也就是我们业务中实际要进行增强的业务对象。
  • AOP Proxy,AOP代理,AOP框架创建的对象。也就是被增强之后的对象。
  • Weaving,织入,把切面连接到其它的应用程序类型或者对象上,并创建一个被通知的对象。就是把切面作用到目标对象,然后产生一个代理对象的过程。

还有另外一个概念,是给类声明额外方法的概念:

  • Introduction,引介,用来给一个类型声明额外的方法或属性。就是我可以不用实现另外一个接口,就能使用那个接口的方法。

通知类型

Advice是通知,也就是在切面的某个连接点上要执行的动作,也就是我们要编写的增强功能的代码。通知也分为好几种类型,分别有不同作用:

  • 前置通知(Before advice):在某连接点之前执行的通知,但这个通知不能阻止连接点之前的执行流程(除非它抛出一个异常)。
  • 后置通知(After returning advice):在某连接点正常完成后执行的通知:例如,一个方法没有抛出任何异常,正常返回。
  • 异常通知(After throwing advice):在方法抛出异常退出时执行的通知。
  • 最终通知(After (finally) advice):当某连接点退出的时候执行的通知(不论是正常返回还是异常退出)。
  • 环绕通知(Around Advice):包围一个连接点的通知,如方法调用。这是最强大的一种通知类型。环绕通知可以在方法调用前后完成自定义的行为。它也会选择是否继续执行连接点或直接返回它自己的返回值或抛出异常来结束执行。

AOP原理

上面说到了AOP可以在编译时候将代码织入到指定的方法或者属性上,或者在运行的时候动态的将代码切入到指定的方法或者属性中,这描述了AOP应该要做的事情,其实也基本算是它的原理了,AOP实现的关键就是创建AOP代理,代理有静态代理和动态代理之分,其中aspectj为静态代理,Spring AOP是动态代理,这里把静态和运行时动态的分开说。

AspectJ编译时增强

aspectj编译时增强,既是静态代理增强,也就是会在编译阶段生成代理,将代码织入到Java的字节码中去。

Spring AOP的运行时增强

Spring AOP是基于代理机制的,并且Spring AOP使用的是动态代理增强,动态代理不会改变类的字节码,而是动态的生成代理对象。Spring AOP的动态代理机制有两种方式:JDK动态代理和CGLIB动态代理。

JDK动态代理

JDK动态代理需要被代理的类必须实现一个接口,通过使用反射来接受被代理的类。

CGLIB动态代理

CGLIB动态代理可以不用需要被代理类必须实现接口,被代理类可以是一个类。

Spring AOP

上面说到了Spring AOP中使用的是动态代理机制,同时也分为两种代理机制:JDK动态代理和CGLIB动态代理,这可以在源码中看到,在DefaultAopProxyFactory的createAopProxy中可看到:

public AopProxy createAopProxy(AdvisedSupport advisedSupport) throws AopConfigException {
    //可以看到这里有条件是没有实现接口
    boolean useCglib = advisedSupport.getOptimize() || advisedSupport.getProxyTargetClass() || advisedSupport.getProxiedInterfaces().length == 0;
    if (useCglib) {
        return CglibProxyFactory.createCglibProxy(advisedSupport);
    }
    else {
        // Depends on whether we have expose proxy or frozen or static ts
        return new JdkDynamicAopProxy(advisedSupport);
    }
}

对于接口的代理使用的JDK动态代理,而对于类的代理使用的是CGLIB动态代理。

AOP的使用场景

AOP适用于具有横切逻辑的应用,比如性能监控,日志记录,缓存,事务管理,访问控制等。

有关Spring AOP的例子可以参考Spring中AOP的配置从1.0到5.0的演进,这里有具体的配置。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容