@PostConstruct项目启动执行两次或多次 @PostConstruct在项目启动时被执行两次或多次的原因及分析

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

@PostConstruct项目启动执行两次或多次 @PostConstruct在项目启动时被执行两次或多次的原因及分析

yinyan1314   2021-08-03 我要评论
想了解@PostConstruct在项目启动时被执行两次或多次的原因及分析的相关内容吗,yinyan1314在本文为您仔细讲解@PostConstruct项目启动执行两次或多次的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:@PostConstruct项目启动,@PostConstruct执行两次,@PostConstruct执行多次,下面大家一起来学习吧。

@PostConstruct项目启动时被执行两次或多次

原因

是因为文件对@PostConstruct所在类扫描了两次!

首先排查,带有扫描包配置(context:component-scan)的同一spring文件,是否在web.xml配置中,初始化就执行的那种配置(比如context-param,init-param),被重复的配置了两遍。

然后在排查,web.xml中配置了初始化配置的多个spring文件是否都扫描了@PostConstruct所在类的所在包!常见SpringMVC文件的扫描路径中也包含了@PostConstruct所在类的所在包。

@PostConstruct执行顺序

最近看到@PostConstruct这个注解,思考一个问题,这个注释是修饰初始化之后需要执行的方法,那么@PostConstruct和@Autowired、构造函数的执行顺序是什么呢?

写了段代码验证一下

@Service
public class BeanA {
    @Autowired
    private BeanB beanB;
    public BeanA() {
        System.out.println("这是Bean A 的构造方法");
    }
    @PostConstruct
    private void init() {
        System.out.println("这是BeanA的 init 方法");
        beanB.testB();
    }
}
@Service
public class BeanB {
    @PostConstruct
    private void init() {
        System.out.println("这是BeanB 的init 方法");
    }
    public BeanB() {
        System.out.println("这是Bean B的 构造方法");
    }
    void testB() {
        System.out.println("这是Bean B 的 testB 方法");
    }
}

启动后输出:

这是Bean A 的构造方法
这是Bean B的 构造方法
这是BeanB 的init 方法
这是BeanA的 init 方法
这是Bean B 的 testB 方法

所以得到结论: 构造方法 > @Autowired > @PostConstruct

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

猜您喜欢

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们