Spring中的实例生成方式及其生命周期
三种实例化bean的方式
1.使用类构造器实例化
<!-- 使用类构造器实例化,class属性表示要使用的类的全限定名 -->
<bean id="userDao1"
class="com.winner.dao.daoImpl.UserDaoImpl">
</bean>
使用反射利用类的无参构造器生成实例。
2.使用静态工厂方法实例化
--配置文件:
<!-- 使用静态工厂方法实例化
class属性表示工厂类的全限定名
factory-method属性表示这个工厂类中用于创建实例的静态方法名(必须是static的)
-->
<bean id="userDao2"
class="com.winner.dao.StaticDaoFactory"
factory-method="createUserDaoInstance">
</bean>
--工厂类:
public class StaticDaoFactory {
// 方法必须声明为static的
public static Object createUserDaoInstance() {
System.out.println("StaticDaoFactory.createUserDaoInstance()");
return new UserDaoImpl();
}
}
3.使用实例化的工厂对象中的方法实例化,首先要构造出工厂实例,然后在生成实例
--配置文件:
<!-- 使用实例化工厂对象中的方法实例化
一、定义工厂bean
二、定义这个bean是由工厂方法创建的,其中:
factory-bean属性表示工厂bean的名称(id或name)
factory-method属性表示这个工厂类中用于创建实例的方法名(不能是static的)
-->
<bean id="simpleDaoFactory"
class="com.winner.dao.SimpleDaoFactory"></bean>
<bean id="userDao3"
factory-bean="simpleDaoFactory"
factory-method="createUserDaoInstance">
</bean>
--工厂类:
public class SimpleDaoFactory {
// 方法不能声明为static的
public static Object createUserDaoInstance() {
System.out.println("SimpleDaoFactory.createUserDaoInstance()");
return new UserDaoImpl();
}
}
我们一般写代码的时候都会分层,显示层,业务层,数据访问层,显示层调用业务层,业务层调用数据访问层。
数据访问层Dao只需要一个实例,业务层Service只需要一个实例,但是action每一次访问都会生成一个实例。
------------
Bean的作用域
在Spring IoC容器中定义的bean默认只有一个实例(单例的),且默认情况下会在容器启动时初始化bean(饿汉式),但我们可以指定Bean节点的lazy-init="true"来延迟初始化bean(懒汉式),这时候,只有第一次获取bean会才初始化bean。如:
--创建类:
public class User {
public User() {
System.out.println("初始化了User...");
}
}
--配置文件:
<!--
scope属性:用于指定bean的生命周期 singleton:单例的,每次ac.getBean()返回的都是同一个实例.
prototype:多例的,第次ac.getBean()返回的都是一个新的实例. 默认为singleton。
lazy-init属性:用于指定在什么时候初始化单例的对象
false:表示在创建ApplicationContext时就初始化本单例的对象。
true:表示在第一次调用getBean()获取本对象时才初始化。 默认为default.
-->
<bean id="user1" class="com.winner.spring.User"/>
或是:
<bean id="user1" class="com.winner.spring.User" scope="singleton"/>
或是:
<bean id="user1" class="com.winner.spring.User" scope="singleton" lazy-init="default"/>
或是
<bean id="user1" class="com.winner.spring.User" scope="singleton" lazy-init="false"/>
以上几种配置,都是在ApplicationContext容器创建时就生成了User对象。
<bean id="user1" class="com.winner.spring.User" scope="singleton" lazy-init="true"/>
当lazy-init取值true时,容器创建不会创建User对象,只有在getBean()时才会创建对象,即延迟加载
对所有bean都应用延迟初始化:
方法是在根节点beans中设置属性default-lazy-init="true",如下所示:
<beans default-lazy-init="true" ...>
prototype(原型,表示每次获取的都是新对象)
每次从容器获取bean都是新的对象。
<bean id="user1" class="com.winner.spring.User" scope="prototype"/>
getBean()时生成实例。
指定Bean的初始化方法和销毁方法
--创建类:
public class UserDao {
private DataSource dataSource;
public DataSource getDataSource() {
return dataSource;
}
public void setDataSource(DataSource dataSource) {
this.dataSource = dataSource;
}
/**
* 初始化方法
*/
public void init() {
System.out.println("UserDao.init() 初始化方法");
}
/**
* 销毁的方法
*/
public void destroy() {
System.out.println("UserDao.destroy() 销毁的方法");
}
}
--配置:
<!-- 单例的对象,配置了初始化方法与销毁方法 -->
<bean id="userDao" class="com.winner.spring.UserDao"
init-method="init" destroy-method="destroy"
/>
--测试代码:
// 在ApplicationContext接口中没有定义close()方法,要想调用,就得先转为子类类型才行。
// 一定要关闭ApplicationContext,给bean配置的销毁方法才会被调用。
// 在单例时,配置的初始化与销毁方法都会被调用。
// 在多例时,只有配置的初始化才会被调用。
@Test
public void test() throws Exception {
ClassPathXmlApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml", getClass());
UserDao userDao = (UserDao) ac.getBean("userDao");
System.out.println(userDao); ac.close();
}
--注意:
---如果scope属性为prototype则不受spring缓存的控制,destory方法也将不会执行(scope调为singleton时才会有效)。
---要调用ApplicationContext的close()方法才会执行destory方法(在ApplicationContext接口中没有close()方法,需要强转为具体的实现类才可以调用)
Spring中的实例生成方式及其生命周期的更多相关文章
- Spring中与bean有关的生命周期
前言 记得以前的时候,每次提起Spring中的bean相关的生命周期时,内心都无比的恐惧,因为好像有很多,自己又理不清楚,然后看网上的帖子,好像都是那么一套,什么beanFactory啊,aware接 ...
- 详解Spring中Bean的作用域与生命周期
摘要:在利用Spring进行IOC配置时,关于bean的配置和使用一直都是比较重要的一部分,同时如何合理的使用和创建bean对象,也是小伙伴们在学习和使用Spring时需要注意的部分,所以这一篇文章我 ...
- Spring中Bean的作用域、生命周期
Bean的作用域.生命周期 Bean的作用域 Spring 3中为Bean定义了5中作用域,分别为singleton(单例).protot ...
- Spring中bean的作用域与生命周期
在 Spring 中,那些组成应用程序的主体及由 Spring IOC 容器所管理的对象,被称之为 bean.简单地讲,bean 就是由 IOC 容器初始化.装配及管理的对象,除此之外,bean 就与 ...
- Spring中Bean的作用域和生命周期
作用域的种类 Spring 容器在初始化一个 Bean 的实例时,同时会指定该实例的作用域.Spring3 为 Bean 定义了五种作用域,具体如下. 1)singleton 单例模式,使用 sing ...
- 阶段3 2.Spring_03.Spring的 IOC 和 DI_8 spring中bean的细节之生命周期
区分单例还是多例对象 单例的几个状态 初始化方法和销毁方法 设置成我们定义的方法 测试 有创建和初始化.但是没有销毁,.对象一直没有销毁的方法 main方法是一切应用程序的入门.当main方法结束后. ...
- 如何在web.config文件中配置Session变量的生命周期
实例说明:在网上购物商城中,为了维护在线购物环境,一般只有注册会员才可以购买商品.实现购物功能时,先通过Session变量记录会员的登录名,然后在购买商品页面通过判断会员是否登录确定其能否购买商品. ...
- Flutter--Flutter中Widget、App的生命周期
前言 在App的开发过程中,我们通常都需要了解App以及各个页面的生命周期,方便我们在App进入前台时启动一些任务,在进入后台后暂停一些任务.同时,各个页面的生命周期也很重要,每个页面消失时要做一些内 ...
- C/C++——C++变量的作用域与生命周期,C语言中变量的作用域和生命周期
全局变量 作用域:全局作用域(全局变量只需在一个源文件中定义,就可以作用于所有的源文件.) 生命周期:程序运行期一直存在 引用方法:其他文件中要使用必须用extern 关键字声明要引用的全局变量. 内 ...
随机推荐
- CodeForces 679B(Bear and Tower of Cubes)
题意:Limak要垒一座由立方体垒成的塔.现有无穷多个不同棱长(a>=1)的立方体.要求:1.塔的体积为X(X<=m).2.在小于X的前提下,每次都选体积最大的砖块.3.在砖块数最多的前提 ...
- KnockoutJS(4)-控制文本和外观绑定
控制文本和外观绑定 依赖关系:除了Knockout核心库之外,无依赖关系. 类别 目的 Visible绑定 Visible绑定通过绑定一个值来确定DOM元素显示或隐藏 Text绑定 Text绑定主要是 ...
- input onfocus onblur
<input type="text" style="color:#999" value="账户" onfocus='if(this.v ...
- centos 7 lNMP 安装之php 篇
1.准备工作 安装依赖包 yum install -y gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype ...
- MongoDB之【增加用户认证、增加用户、删除用户、修改用户密码、读写权限、只读权限】
说明:增加用户是针对数据库进行操作 1.进入到数据库 use dbname 2.针对当前数据库添加用户 权限是针对当前数据 1.添加并验证用户 > use admin > db.addUs ...
- 使用PHP获取汉字的拼音(全部与首字母)
<?php /** * 取汉字拼音 * edit by www.jbxue.com */ class GetPingYing { private $pylist = array( 'a'=> ...
- php中封装的curl函数(抓取数据)
介绍一个封闭好的函数,封闭了curl函数的常用步骤,方便抓取数据. 代码如下: <?php /** * 封闭好的 curl函数 * 用途:抓取数据 * edit by www.jbxue.com ...
- unity3d应用内分享(微信、微博等)的实现
问题:如何在unity3d的游戏中实现分享功能,如图 思路: 1.分享功能的实现方式有多种,较方便快捷的一种是直接调用android的API来调出系统的分享界面 2.unity3d里面调用androi ...
- what is the purpose of channel coding?(信道编码的作用?)
信道.信道编码及其作用 1.信道(channel) 信道和通信电路并不等同,用来表示向某一个方向传送信息的媒体.因此一条通信线路往往包含一条发送信道和一条接收信道. 从通信的双方信息交互方式看有三个基 ...
- javascript看你能够做对几题
http://ourjs.com/detail/52fb82e13bd19c4814000001