最近使用到了基于aspectj的spring aop, aop是spring的核心之一, 重要性自必不多言, 而使用aspectj在spring中的应用让我们的开发工作量降低了不少, 不过里面有一点在spring的reference中没有提到, 而且这一点我觉得是非常重要的, 因为这个问题导致我在开发中郁闷了好久, 就是返回值的问题, [size=large][color=red]当使用Around Advice的时候, 被around的方法如果是有返回值的, 那么在使用ProceedingJoinPoint 的时候一定要有返回值[/color][/size], 比如这样写:
否则就会抛出NullPointerException, 就像下面的堆栈信息:
[quote]java.lang.NullPointerException
at $Proxy6.deleteDocument(Unknown Source)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)[/quote]
由于spring内部采用cglib动态生成了一些类, 因此调试的时候也看不到源码, 给查找问题又带来了困难
@Around("com.xyz.myapp.SystemArchitecture.businessService()")
public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable {
// start stopwatch
Object retVal = pjp.proceed();
// stop stopwatch
return retVal;
}
否则就会抛出NullPointerException, 就像下面的堆栈信息:
[quote]java.lang.NullPointerException
at $Proxy6.deleteDocument(Unknown Source)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)[/quote]
由于spring内部采用cglib动态生成了一些类, 因此调试的时候也看不到源码, 给查找问题又带来了困难