6

我有这样的课:

    public class Loader implements DisposableBean { 

        Class1 c1;
        Class2 c2;

        Loader(Class c1, Class c2) {
          this.c1 = c1;
          this.c2 = c2; 
    }
    @Override
    public void destroy() throws Exception {
        c1.do();
        c2.do();
    }
}

它被创建为@Configuration 类中的@Bean。

@Bean(autowire = Autowire.BY_NAME, name = "loader")
public Loader getLoader() {
    return new Loader(getC1(), getC2());
}

它通过我的 web.xml 中的上下文加载器侦听器进行实例化

<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext-loader.xml</param-value>
</context-param>

使用具有此行的应用程序上下文:

<context:component-scan base-package="name.of.package.loader.is.in" />

在 tomcat 中开始战争时,我在构造函数中放置了一个断点,我可以验证 c1 和 c2 是否按预期填充。但是,当我关闭 tomcat 并进入 destroy 方法时,c1 和 c2 都为空,因此抛出了 NPE。为什么这些价值观不再存在?


啊,该死的,应该再深入一点。它在我不熟悉的代码部分中被清除,我终于找到了它。

4

0 回答 0