在默认情况下,
ApplicationContext在初始化过程中可以轻易创建并配置所有的singleton beans。这些 pre-instantiation都很令人满意,因为这样子很容易发现配置或者是环境的错误,
<!-- no beans will be pre-instantiated... -->
</beans>
而不是几个小时甚至几天后才发现这些错误。当这些行为不适合我们的时候,我们可以通过定义bean为延迟初始化阻止 singleton bean 的 pre-instantiated 。一个延迟加载的bean会告诉Ioc容器,第一次使用它的时候创建bean,而不是在启动的时候创建。
在XML文件中,这些行为是通过 <bean/>节点里面的 lazy-init属性控制;例如:
<bean id="lazy" class="com.foo.ExpensiveToCreateBean" lazy-init="true"/>
<bean name="not.lazy" class="com.foo.AnotherBean"/>
<bean name="not.lazy" class="com.foo.AnotherBean"/>
ApplicationContext 消耗完之前的配置,当 ApplicationContext 启动时不会马上 pre-instantiated 那些定义为 lazy 的 bean,相反,ApplicationContext 启动时会马上 pre-instantiated 那些定义为 not.lazy
的 bean。
然而,如果一个延迟加载的 bean 是另一个 singleton bean 的依赖,这个 bean 就不会延迟加载,ApplicationContext 会在启动的时候创建这个 bean。因为这个bean必须满足 singleton bean 的依赖性。延迟加载的 bean注入到一个 singleton bean 在其他地方不会延迟加载。
你也可以通过使用<beans/>节点里面的default-lazy-init变量在容器水平上控制延迟加载。例如:
<beans default-lazy-init="true"><!-- no beans will be pre-instantiated... -->
</beans>