关于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方法,连续多次执行,会产生不一样的后果,不具有幂等性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值