@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,把你需要调用的静态方法放到非静态方法中进行调用

posted @   初见洞洞拐  阅读(151)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
· 提示词工程——AI应用必不可少的技术
点击右上角即可分享
微信分享提示