今天在排查日志的时候发现,有个服务的定时任务一直在报错,但是却没有影响报错的地方代码执行,报错日志如下:
Error:"Null return value from advice does not match primitive return type"
代码如下:
@Override
@Async
public int execute(){
//service code
return 1;
}
报错原因是代码中使用了@Async来做了异步线程,原理是aop做了一层切面处理,底层是通过jdk动态代理来实现的,在动态代理的返回值为void就return null,否则就 return method.invoke(my, args)
也就是说动态代理在没有返回值时就会返回null,所以方法返回值不能使用基础数据类型来接收,否则就会报错
但是因为报错是异步线程已经执行完成时才报出的,所以并不影响当前execute()方法内的业务代码的执行,但是该方法执行完,会影响后续代码执行
所以尽量使用包装类来接收