@Around对静态方法不生效问题

场景:

在处理定时任务时,由于这几个方法都是静态方法,在aop的切面中使用@Around注解,进行监控方法调用是否有异常。发现aop没有生效。代码如下:

/*切面类*/
@Aspect
@Component
public class RetryAop {
    private static Logger logger = LoggerFactory.getLogger(RetryAop.class);
    @Around(value = "@annotation(TechlogRetry)")
    public Object monitorAround(ProceedingJoinPoint pjp) throws Throwable {
    }
}
/*对应的注解,在需要的方法上进行标注*/
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface TechlogRetry {
    long waitMsec() default 0;
    Class[] retryThrowable() default {};
}
/*对应的测试方法*/
@Component
@EnableScheduling
public class TimerWork {
    // 成员方法可以成功调用
    @Scheduled(cron = "*/5 * * * * ?")
    @TechlogRetry(waitMsec = 3000,retryThrowable = Exception.class)
    public void work1() {
        System.out.println("定时方法1.。。。。。。");
        throw new NullPointerException("抛出异常");
    }
     // 静态方法不会进行重试
	@Scheduled(cron = "*/5 * * * * ?")
    @TechlogRetry(waitMsec = 3000,retryThrowable = Exception.class)
    public static void work2() {
        System.out.println("定时方法2.。。。。。。");
        throw new NullPointerException("抛出异常");
    }
    // 通过这种方式生效
    @Scheduled(cron = "*/5 * * * * ?")
    @TechlogRetry(waitMsec = 3000,retryThrowable = Exception.class)
    public void work4() {
        System.out.println("这是work4.。。。");
        TimerWork.work2();// 调用work2时,注释掉方法2上面的相关注解
    }
    
}

产生原因:可能是由于静态方法是属于类的,而非静态方法是属于Bean的,该类会被加载到容器中。具体原因需要查资料,后续进行补充。

解决:如work4,把你需要调用的静态方法放到非静态方法中进行调用

发布了59 篇原创文章 · 获赞 33 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_41010294/article/details/103271337