前言
最近遇到了一个启动失败的问题,原因是在bean初始化完成之后的钩子方法中使用获取容器中bean的工具类,(对应工具类之前的一篇博客 获取springbean))。
分析
这里具体的场景是我想实现一个bean在钩子方法中往一个策略map中注册自己作为一个策略使用,但是在启动的时候报错:
第33行代码如下:
1 | public static <T> T getBean(@NotNull Class<T> tClass) { |
可以看到可能为空的是context,这个是通过在项目中启动时注入到ApplicationContextUtil中的静态变量context,很明显是在当前这个bean启动的时候,其钩子方法去调用这个变量还没实现context的注入。
1 |
|
解决
这里主要是一个场景,其实在bean启动的时候是依赖ApplicationContextUtil这个bean的,但是因为getBean方法都static方法,在平常业务代码中调用都是容器启动完毕的时候,所以没有问题,但是这里是想实现在bean初始化时自动通过钩子往一个map工厂中注册bean实例,且该bean没有显示的@Resource依赖ApplicationContextUtil,所以在注册的时候applicationContextutil这个bean还没初始化好,这里在这些具体策略的类上加了@DependsOn(“applicationContextUtil”)
1 |
|
这表示这个bean的初始化是依赖 applicationContextUtil 这个bean初始化完成之后(也就是静态变量上下文被注入)才去初始化的,这样启动就不会报NPE了。