1. Bean 的实例化与初始化过程
- 在 Spring 中,当配置了基于静态工厂的 Bean 时,容器在启动加载配置文件的过程中就会开始处理 Bean 的定义。即使没有主动获取对应 Bean 的 id 来使用这个 Bean,Spring 容器仍然会根据配置文件中的定义尝试实例化这个 Bean。
- 容器会解析配置文件中的
<bean>
元素,识别出这是一个通过静态工厂方法创建的 Bean。然后,它会查找指定的静态工厂类和静态工厂方法。
2. 静态工厂方法执行逻辑
- 当调用静态工厂方法来创建 Bean 时,如果在静态工厂方法内部有数据输出(例如打印日志或者进行一些初始化时的输出操作),这些输出操作就会被执行。
- 例如,静态工厂类如下
public class MyStaticFactory {
public static MyObject createMyObject() {
System.out.println("执行静态工厂方法,可能用于初始化某些资源或记录日志");
return new MyObject();
}
}
对应的 Spring 配置文件:
<bean id="myObject" class="com.example.MyStaticFactory" factory - method="createMyObject"/>
在容器加载这个配置文件时,一旦解析到这个<bean>
的定义,就会调用MyStaticFactory.createMyObject
方法,从而导致其中的输出语句被执行,而不需要显式地获取myObject
这个 Bean 的 id 去触发操作。
3. 容器的预加载机制
- Spring 容器为了提高应用的性能和资源管理的效率,可能会采用预加载机制。在这种机制下,容器会提前对配置文件中的 Bean 进行实例化(包括通过静态工厂创建的 Bean),以避免在后续真正需要使用 Bean 时再进行实例化带来的延迟。这种预加载过程中如果涉及到静态工厂方法的调用,其中的输出操作就会被执行。