关于spring框架使用bean注解初始化的一点认识

今天用bean注解来初始化scheduledTaskRegistrar类。在方法中new以后,调用setcrontaskList方法以后,很自然的调用了afterPropertiesSet方法

运行debug,发现cron任务会被连续调用两次。

排查方向1  cron表达式有问题,这个排查发现没问题,用最简单的cron表达式做的测试。

排查方向2 怀疑setcrontaskList设置时的list数据条数,认真degbu核查,数据条数正常

没啥想法了,开始各种无端猜疑,有些猜想,自己都不认可,也拿来试试,死马当活马医嘛。不小心进了afterPropertiesSet方法内部,看到了一段代码,豁然开朗。

if(this.cronTasks != null) {
    for(CronTask task : this.cronTasks) {
        this.scheduledFutures.add(this.taskScheduler.schedule(
               task.getRunnable(), task.getTrigger()));
    }
}

如果代码被执行两次 ,不就会这样了吗?

马上立刻,删除方法调用,再执行,一切OK.

框架在使用bean注解的方法得到对象后,会调用实现了InitializingBean接口的对象的afterPropertiesSet方法,如果方法内再调用,会有可能出现一些奇怪的行为。这个类的afterPropertiesSet方法,连续多次执行,会产生不一样的后果,不具有幂等性。

你可能感兴趣的:(技術,spring,java,cron)