今天想写个同步锁的功能,第一反应自然是切面,但写出来之后怎么调试切面都不执行,折腾一下午最后无意中发现了问题所在。
在new文件的时候,注意这个Aspect的选项,当时我想都没想就选了他。
通过他建立的文件是不一样的,后缀名是.aj
而不是.java
,但坑爹的是语法和java完全一样,编译运行也都没有任何异常,就是不执行!!手动把文件后缀改成.java
之后一切正常。
这个小问题折腾了整整一下午,要不是打算临时提交git根本注意不到这个小后缀名的区别,太坑了。
另外多查了一下AspectJ的文件需要单独的编译器才能运行。
- AOP无法切入private
另外记录一个坑点,切面不能切入private
方法,原因可以简单理解为就像反射不能获取私有成员一样,详细原理可以看这里。
- AOP无法切入方法内部调用
今天刚发现的,比方说service中有个方法A,controller中调用的是service.A(),而方法A()中内部调用了方法B和方法C。此时注解打在A()上面是没有问题的,打在B()或C()上是没有效果的,原因和上面类似,都是由于代理类的问题,见下图
参考文章看这里。