情况说明: 在一个抽象类中使用@PostConstruct注解方法init用于初始化操作。然后每个实现类在初始化时都会调用@PostConstruct注解的init方法执行初始化操作。如下代码:
public abstract class AbstractClass {
/**
* 存放各实例.
*/
public static final Map<Integer, AbstractClass > INSTANCES = new ConcurrentHashMap<>();
protected abstract void doSomething();
/**
* 初始化操作.
*/
@PostConstruct
void init() {
INSTANCES.put(getCostSoc(), this);
}
}
@Service
public abstract class Class1 extends AbstractClass {
protected abstract void doSomething() {
// do something
}
}
@Service
public abstract class Class2 extends AbstractClass {
protected abstract void doSomething() {
// do something
}
}
遇到问题: 本来好好地,但是在另外一个环境却发现程序启动时不执行@PostConstruct注解的init方法了,导致在使用INSTANCES获取实例时获取到的是null。进而导致后面业务走不下去。
原因分析: 经过分析最终得出的结论是,这个环境不知道怎么配了默认懒加载,
而懒加载情况下,在程序启动时是不会执行@PostConstruct注解的方法的。
解决问题: 经过尝试有两种方式可以解决这种问题。
1. 配置@Lazy(false)取消懒加载,如下:
@Service
@Lazy(false)
public abstract class Class1 extends AbstractClass
@Service
@Lazy(false)
public abstract class Class2 extends AbstractClass
2. 在另一个bean BizService中依赖AbstractClass,这样在BizService实例化时需要先实例化依赖的bean,进而触发AbstractClass的实例化,进而执行@PostConstruct注解的方法。如下:
@Service
public class BizService {
@Autowired
@Qualifier("class1")
private AbstractClass class1;
@Autowired
@Qualifier("class2")
private AbstractClass class2;
}