AspectJ 实现代理

《两种动态代理:JDK实现和CGLIB字节码生成文件》

《java中的代理(静态代理和动态代理)》

先复习一下,看一下之前的两篇文章

然后我们说一说AspectJ代理:
AspectJ静态编译织入(Aspect for java),他其实是一套独立的面向切面编程的解决方案。Spring中虽然使用了Aspect的Annotation,但是并没有使用它的编译器和织入器。

关于AOP的相关概念学习可以看:《SpringAOP基础以及四种实现方式》

添加如下配置就可以启用Spring对@AspectJ方面配置的支持。

 <aop:aspectj-autoproxy/>

我们知道静态代理唯一的缺点就是我们需要对每一个方法编写我们的代理逻辑,造成了工作的繁琐和复杂。AspectJ就是为了解决这个问题,在编译成class字节码的时候在方法周围加上业务逻辑。复杂的工作由特定的编译器帮我们做。

它其实不是一个新的语言,它就是一个代码编译器(也就是AJC),在Java编译器的基础上增加了一些它自己的关键字识别和编译方法。因此,ajc也可以编译Java代码。它在编译期将开发者编写的Aspect程序编织到目标程序中,对目标程序作了重构,目的就是建立目标程序与Aspect程序的连接(耦合,获得对方的引用(默认情况下,也就是不使用this或target来约束切点的情况下,那么获得的是声明类型,不是运行时类型)和上下文信息),从而达到AOP的目的(这里在编译期还是修改了原来程序的代码,但是是AJC替我们做的)。

小结

  1. Aspectj并不是动态的在运行时生成代理类,而是在编译的时候就植入代码到class文件
  2. 由于是静态织入的,所以性能相对来说比较好
  3. Aspectj不受类的特殊限制,不管方法是private、或者static、或者final的,都可以代理
  4. Aspectj不会代理除了限定方法之外任何其他诸如toString(),clone()等方法

猜你喜欢

转载自blog.csdn.net/mulinsen77/article/details/89414745