`
lushuaiyin
  • 浏览: 676046 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

spring的延迟初始化bean (default-lazy-init 与 lazy-init )

 
阅读更多

ApplicationContext实现的默认行为就是在启动时将所有singleton bean提前进行实例化。提前实例化意味着作为初始化过程的一部分,ApplicationContext实例会创建并配置所有的singleton bean。通常情况下这是件好事,因为这样在配置中的任何错误就会即刻被发现(否则的话可能要花几个小时甚至几天)。

有时候这种默认处理可能并不是你想要的。如果你不想让一个singleton bean在ApplicationContext实现在初始化时被提前实例化,那么可以将bean设置为延迟实例化。一个延迟初始化bean将告诉IoC 容器是在启动时还是在第一次被用到时实例化。

在XML配置文件中,延迟初始化将通过<bean/>元素中的lazy-init属性来进行控制。例如:

<bean id="lazy" class="com.foo.ExpensiveToCreateBean" lazy-init="true"> <!-- various properties here... --> </bean> <bean name="not.lazy" class="com.foo.AnotherBean"> <!-- various properties here... --> </bean>



ApplicationContext实现加载上述配置时,设置为lazy的bean将不会ApplicationContext启动时提前被实例化,而not.lazy却会被提前实例化。

需要说明的是,如果一个bean被设置为延迟初始化,而另一个非延迟初始化的singleton bean依赖于它,那么当ApplicationContext提前实例化singleton bean时,它必须也确保所有上述singleton 依赖bean也被预先初始化,当然也包括设置为延迟实例化的bean。因此,如果Ioc容器在启动的时候创建了那些设置为延迟实例化的bean的实例,你也不要觉得奇怪,因为那些延迟初始化的bean可能在配置的某个地方被注入到了一个非延迟初始化singleton bean里面。

在容器层次中通过在<beans/>元素上使用'default-lazy-init'属性来控制延迟初始化也是可能的。如下面的配置:

<beans default-lazy-init="true"> <!-- no beans will be eagerly pre-instantiated... --> </beans>



在同一个文件中<bean />里面设置的优先级大于<beans />里设置的优先级:

  1. <beans/><bean/>immediately
  2. <beans/><beanlazy-init="true"/>lazy
  3. <beans/><beanlazy-init="false"/>immediately
  4. <beansdefault-lazy-init="true"/><bean/>lazy
  5. <beansdefault-lazy-init="true"/><beanlazy-init="true"/>lazy
  6. <beansdefault-lazy-init="true"/><beanlazy-init="false"/>immediately
  7. <beansdefault-lazy-init="false"/><bean/>immediately
  8. <beansdefault-lazy-init="false"/><beanlazy-init="true"/>lazy
  9. <beansdefault-lazy-init="false"/><beanlazy-init="false"/>immediately

如果在一个spring配置文件中引入另外的配置文件,如:<import resource="classpath:beanss.xml"/>

则以被引入文件(beanss.xml)中设置的<beans />里的设置为准,与引入文件中的设置无关。

  1. <beanid="testInit"lazy-init="true"init-method="init"class="com.test.Test">
  2. </bean>





  


  
分享到:
评论

相关推荐

    浅谈spring中的default-lazy-init参数和lazy-init

    下面小编就为大家带来一篇浅谈spring中的default-lazy-init参数和lazy-init。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

    图片延迟加载-juery-lazyload

    图片延迟加载-juery-lazyload 很不错

    前端开源库-markdown-it-lazy-headers

    前端开源库-markdown-it-lazy-headersMarkdown it Lazy Headers,Lazy ATX Headers插件用于Markdown it

    前端项目-vue-lazyload.zip

    前端项目-vue-lazyload,用于在Vue.js应用程序中延迟加载图像的Vue模块。

    spring1.2学习心得分享

    初始化:&lt;bean init-method=""/&gt; e.资源释放:&lt;bean destroy-method=""/&gt;仅对单例对象有效 (2)IoC概念 Inversion of Control 控制反转或控制转移 Don't Call Me,We will call you! 控制权:对象的创建和调用...

    前端项目-vanilla-lazyload.zip

    前端项目-vanilla-lazyload,Lazyload是一个快速、轻量级和灵活的脚本,仅在图像即将进入可滚动区域的视区时才加载图像,并对渐进式JPEG图像格式提供了极好的支持。类型脚本模块定义可用。

    spring学习心得

    初始化:&lt;bean init-method=""/&gt; e.资源释放:&lt;bean destroy-method=""/&gt;仅对单例对象有效 (2)IoC概念 Inversion of Control 控制反转或控制转移 Don't Call Me,We will call you! 控制权:对象的创建和调用...

    spring1.1开发理解

    初始化:&lt;bean init-method=""/&gt; e.资源释放:&lt;bean destroy-method=""/&gt;仅对单例对象有效 (2)IoC概念 Inversion of Control 控制反转或控制转移 Don't Call Me,We will call you! 控制权:对象的创建和调用...

    前端项目-jquery-lazyload-any.zip

    前端项目-jquery-lazyload-any,jquery插件为图像、iframe或任何东西提供了lazyload函数。

    前端开源库-lazy-dependable

    前端开源库-lazy-dependable懒惰可靠,通过懒惰依赖解析实现可靠

    ng2-image-lazy-load, Angular2图像迟缓加载程序库.zip

    ng2-image-lazy-load, Angular2图像迟缓加载程序库 当前未维护现在,你可以尝试使用这个伟大的延迟加载 库来实现。 上面的库唯一没有的是Web工作支持- 我希望在未来的某个时候循环,或者者为tjoskar提供辅助。 ng2-...

    spring 配置文件简单说明

    1. 1)default-init-method ="方法名" 定义在此配置文件中的bean都会执行指定的init方法。 2)default-destroy-...3)default-lazy-init ="false|true" 定义在此配置文件中的bean都会延迟加载。 ....................

    react-lazy-load-image-component-demo:react-lazy-load-image-component 演示

    这是react-lazy-load-image-component NPM 包的演示。 它既不打算在现实生活中使用,也不是好的编程实践的一个例子,而是要给出一个如何使用包react-lazy-load-image-component及其道具的例子。 观看现场演示: : ...

    hexo-lazyload-image:用于Hexo的lazyload图像插件

    hexo-lazyload-image hexo-lazyload-image是一个hexo插件,用于使所有图像自动支持lazyload。 借助此功能,它将改善很多加载性能。 所有延迟加载图像仅在它们位于当前视口内时显示。 不必担心lazyload SEO问题,因为...

    hqy-lazyload:一种快速,轻量级的纯JavaScript脚本,用于延迟加载和提供多张图片,iframe,视频等内容

    hqy-lazyload 一个轻量级的纯JavaScript脚本,用于延迟加载和多服务图像。 它可以在包括IE7 +在内的所有现代浏览器中使用。 它是用纯JavaScript编写的,因此它不依赖于jQuery之类的第三方库。 它使您可以延迟加载...

    延迟图像加载Mojito-Image-Lazyload​.zip

    Mojito-Image-Lazyload 是一个 Mojito 框架下延迟图像加载的开发包。 标签:Mojito 分享 window._bd_share_config = { "common": { "bdSnsKey":...

    react-lazy-load, 当子元素进入viewport时,响应它们呈现子元素.zip

    react-lazy-load, 当子元素进入viewport时,响应它们呈现子元素 延迟加载 组件反应 延迟加载 很容易使用响应组件,它帮助你以可以预测的方式延迟加载内容。 速度快,工作在 IE8+,6KB 缩小,在默认情况下使用去抖...

    Laravel开发-laravel-lazy-mysql

    Laravel开发-laravel-lazy-mysql Laravel基于懒惰MySQL的雄辩模型和查询生成器

    import-lazy:延迟导入模块

    延迟导入模块 安装 $ npm install import-lazy 用法 // Pass in `require` or a custom import function const importLazy = require ( 'import-lazy' ) ( require ) ; const _ = importLazy ( 'lodash' ) ; // ...

    基于Vue的延迟加载插件vue-view-lazy

    主要介绍了基于Vue的延迟加载插件vue-view-lazy,可以使图片或者其他资源进入可视区域后加载,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

Global site tag (gtag.js) - Google Analytics