BeanFactory 除了拥有作为IoC的职责,作为一个轻量级容器,它还有着其他一些
职责,其中就包括对象的生命周期管理。
scope用来声明容器中的对象所应该处的限定场景或者说该对象的存活时间,即容器在对象进入其
相应的scope之前,生成并装配这些对象,在该对象不再处于这些scope的限定之后,容器通常会销毁
Spring容器最初提供了两种bean的scope类型:singleton和prototype,但发布2.0之后,又引入了另
外三种scope类型,即request、session和global session类型。不过这三种类型有所限制,只能在Web应
用中使用。
- singleton
标记为拥有singleton scope的对象定义,在Spring的IoC容器中只存在一个实例,所有对该对象的引
用将共享这个实例。该实例从容器启动,并因为第一次被请求而初始化之后,将一直存活到容器退出,
也就是说,它与IoC容器“几乎”拥有相同的“寿命”。
- prototype
针对声明为拥有prototype scope的bean定义,容器在接到该类型对象的请求的时候,会每次都重新
生成一个新的对象实例给请求方。虽然这种类型的对象的实例化以及属性设置等工作都是由容器负责
的,但是只要准备完毕,并且对象实例返回给请求方之后,容器就不再拥有当前返回对象的引用,请
求方需要自己负责当前返回对象的后继生命周期的管理工作,包括该对象的销毁。也就是说,容器每
次返回给请求方一个新的对象实例之后,就任由这个对象实例“自生自灭”了。
例子
<beans>
<!--这是吃橘子的Bean -->
<bean id="eatOrange" class="it.spring.liao.com.EatOrange" scope="singleton"></bean>
<!--这是吃苹果的Bean -->
<bean id="eatApple" class="it.spring.liao.com.EatApple" scope="prototype"></bean>
<bean id="person" class="it.spring.liao.com.Person">
<!-- 这里我们注入的是吃橘子的bean-->
<property name="eat" ref="eatOrange"/>
</bean>
</beans>
- request、session和global session
这三个scope类型是Spirng 2.0之后新增加的,它们不像之前的singleton和prototype那么“通用”,
因为它们只适用于Web应用程序。
request
request通常的配置形式如下:
<bean id="eatApple" class="...EatApple" scope="request"/>
Spring容器,即 WebApplicationContext 会为每个HTTP请求创建一个全新的 EatApple 对象供当前请求使用,当请求结束后,该对象实例的生命周期即告结束。当同时有10个HTTP
请求进来的时候,容器会分别针对这10个请求返回10个全新的 EatApple 对象实例,且它们
之间互不干扰。从不是很严格的意义上说,request可以看作prototype的一种特例,除了场景更加具体
之外,语意上差不多。
session
对于Web应用来说,放到session中的最普遍的信息就是用户的登录信息,对于这种放到session中
的信息,Spring容器会为每个独立的session创建属于它们自己的全新的 EatApple对象实例。我们可使用如下形式指定其scope为session:
<bean id="eatApple" class="...EatApple" scope="scope"/>
global session只有应用在基于portlet的Web应用程序中才有意义,它映射到portlet的global范围的
session。如果在普通的基于servlet的Web应用中使用了这个类型的scope,容器会将其作为普通的session
类型的scope对待。