`

spring aspectj的返回值

阅读更多
最近使用到了基于aspectj的spring aop, aop是spring的核心之一, 重要性自必不多言, 而使用aspectj在spring中的应用让我们的开发工作量降低了不少, 不过里面有一点在spring的reference中没有提到, 而且这一点我觉得是非常重要的, 因为这个问题导致我在开发中郁闷了好久, 就是返回值的问题, 当使用Around Advice的时候, 被around的方法如果是有返回值的, 那么在使用ProceedingJoinPoint 的时候一定要有返回值, 比如这样写:
@Around("com.xyz.myapp.SystemArchitecture.businessService()")
  public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable {
	// start stopwatch
	Object retVal = pjp.proceed();
	// stop stopwatch
	return retVal;
  }

否则就会抛出NullPointerException, 就像下面的堆栈信息:
引用
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)

由于spring内部采用cglib动态生成了一些类, 因此调试的时候也看不到源码, 给查找问题又带来了困难
分享到:
评论
1 楼 jake0719 2009-06-29  
cglib生成的只是代理类, 把断点打在所代理的实体类里面不还是可以debug到你的class的么?

相关推荐

Global site tag (gtag.js) - Google Analytics