|
此版本仍在开发中,尚未稳定。如需最新的稳定版本,请使用 Spring Framework 7.0.6! |
延迟初始化的Bean
默认情况下,ApplicationContext 实现会在初始化过程中急切地创建和配置所有
单例 bean。通常,这种预实例化是可取的,因为可以在配置或周围环境中的错误被立即发现,而不是在数小时甚至数天之后。当这种行为不可取时,可以通过将 bean 定义标记为延迟初始化来防止单例 bean 的预实例化。延迟初始化的 bean 会告诉 IoC 容器在首次请求时创建 bean 实例,而不是在启动时。
此行为由 @Lazy 注解或在 XML 中的 <bean/> 元素上的 lazy-init 属性控制,如下例所示:
-
Java
-
Kotlin
-
Xml
@Bean
@Lazy
ExpensiveToCreateBean lazy() {
return new ExpensiveToCreateBean();
}
@Bean
AnotherBean notLazy() {
return new AnotherBean();
}
@Bean
@Lazy
fun lazy(): ExpensiveToCreateBean {
return ExpensiveToCreateBean()
}
@Bean
fun notLazy(): AnotherBean {
return AnotherBean()
}
<bean id="lazy" class="com.something.ExpensiveToCreateBean" lazy-init="true"/>
<bean name="notLazy" class="com.something.AnotherBean"/>
当上述配置被 ApplicationContext 使用时,lazy bean 在 ApplicationContext 启动时不会被急切地预先实例化,而 notLazy 则会被急切地预先实例化。
然而,当一个延迟初始化的bean是另一个非延迟初始化的单例bean的依赖项时,ApplicationContext会在启动时创建这个延迟初始化的bean,因为它必须满足单例bean的依赖项。这个延迟初始化的bean会被注入到其他非延迟初始化的单例bean中。
您还可以通过在使用 @Configuration 注解的类上使用 @Lazy 注解,或在 XML 中的 <beans/> 元素上使用 default-lazy-init 属性来控制一组 Bean 的延迟初始化,如下例所示:
-
Java
-
Kotlin
-
Xml
@Configuration
@Lazy
public class LazyConfiguration {
// No bean will be pre-instantiated...
}
@Configuration
@Lazy
class LazyConfiguration {
// No bean will be pre-instantiated...
}
<beans default-lazy-init="true">
<!-- No bean will be pre-instantiated... -->
</beans>