[译]8-spring bean的作用域
在spring中使用<bean/>标签定义bean的时候,可以使用scope属性来定义bean的作用域.如果想要每次
从spring容器得到一个新创建的bean实例,可以指定scope="prototype";如果想要每次从spring容器得
到同一个bean实例,可以指定scope="singleton"
spring中bean的作用域有如下5种类,其中有3中适用于web应用程序.5中作用域的介绍如下:
作用域 | 说明 |
singleton | 单例bean.整个IOC容器中只有该bean的一个实例 |
prototype | 原型.每次从spring IOC容器中得到的都是新创建的bean |
request | 每次http请求都会创建一个bean.只适用于web应用 |
session | 每个session共用一个bean.只适用于web应用 |
global-session | 整个web应用中只会实例化一次该bean |
本文我们只介绍singleton和prototype作用域.
singleton作用域
在spring IOC容器中的bean如果scope指定为singleton,那么该bean在此IOC容器中只会存在一个实例.
首次从spring IOC容器中获得该bean的时候,spring IOC容器会实例化并装配该bean,随后把该bean
缓存起来,以后在从spring IOC容器取得该bean的时候,IOC容器会把缓存的bean实例返回.
下面看一个singleton作用域的例子程序.
1.创建com.tutorialspoint.scope.singleton包,并在包中创建HelloWorld.java类,内容如下:
package com.tutorialspoint.scope.singleton; public class HelloWorld { private String message; public void setMessage(String message) {
this.message = message;
} public void getMessage() {
System.out.println("Your Message : " + message);
}
}
2.在src目录下,创建scope_singleton.xml配置文件,内容如下:
在配置文件中,指定bean的作用域为singleton.
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <bean id="helloWorld" class="com.tutorialspoint.scope.singleton.HelloWorld" scope="singleton"/> </beans>
3.在包com.tutorialspoint.scope.singleton中创建MainApp.java,内容如下:
package com.tutorialspoint.scope.singleton; import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class MainApp { public static void main(String[] args) { //实例化spring IOC容器
ApplicationContext context = new ClassPathXmlApplicationContext("scope_singleton.xml");
//从容器中得到作用域为singleton的helloWorld bean.并强制转换为HelloWorld
HelloWorld objA = (HelloWorld)context.getBean("helloWorld");
//调用objA的setMessage方法,给成员变量message赋值
objA.setMessage("I am object A");
//打印objA的成员变量message
objA.getMessage();
//再次从spring IOC容器中得到作用域为single的的helloWorld bean
HelloWorld objB = (HelloWorld)context.getBean("helloWorld");
//直接得到objB的成员变量message,可以发现objB的message也被赋值了,说明从IOC容器中得到的是同一个bean实例
objB.getMessage();
//再次确认,看看objA和objB所引用的对象是否是同一个对象,从打印信息中可以验证objA和objB确实是同一个对象
System.out.println(objA==objB);
}
}
4.运行程序验证结果,如下:
最后我们修改scope_singleton.xml配置文件,把scope="singleton"去掉,再次运行程序.发现两次运行
结果完全一致.这就证明了:spring IOC容器所管理的bean的作用域默认情况下是singleton
prototype作用域
spring IOC容器所管理的scope为prototype的bean,在每次用户请求从IOC容器中得到该bean的时候,都
会新创建该bean的一个实例,并返回给用户.一般情况有状态的bean的scope会被设置为prototype;无状态
bean的scope设置为singleton.(可以简单的认为有成员变量,并且会对该变量进行修改的类都是有状态的).
下面做实验,实验代码跟singleton例子中的代码完全一致,只是配置元数据不同.还是在敲一遍吧
1.新建包com.tutorialspoint.scope.prototype,并在包中新建HelloWorld.java,内容如下:
package com.tutorialspoint.scope.prototype; public class HelloWorld { private String message; public void setMessage(String message) {
this.message = message;
} public void getMessage() {
System.out.println("Your Message : " + message);
}
}
2.在src目录下新建scope_prototype.xml文件,内容如下:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <!-- 指定helloWorld bean的scope作用域为prototype -->
<bean id="helloWorld" class="com.tutorialspoint.scope.prototype.HelloWorld" scope="prototype"/> </beans>
3.在包com.tutorialspoint.scope.prototype中新建类MainApp.java,内容如下:
package com.tutorialspoint.scope.prototype;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class MainApp {
public static void main(String[] args) {
//实例化spring IOC容器
ApplicationContext context = new ClassPathXmlApplicationContext("scope_prototype.xml");
//从容器中得到作用域为prototype的helloWorld bean.并强制转换为HelloWorld
HelloWorld objA = (HelloWorld) context.getBean("helloWorld");
//设置objA的message成员变量
objA.setMessage("I'm object A");
//得到objA的message成员变量
objA.getMessage();
//再次从spring IOC容器中得到作用域为prototype的helloWorld bean
HelloWorld objB = (HelloWorld) context.getBean("helloWorld");
//获取objB的message的成员变量.发现message为null,证明objA和objB不是同一个实例
objB.getMessage();
//进一步验证objA和objB所引用的对象是否是同一个
System.out.println(objA==objB);
}
}
4.运行程序,验证结果,发现IOC容器中scope为prototype的bean会为每个请求重新创建实例.
[译]8-spring bean的作用域的更多相关文章
- Spring Bean的作用域(转)
Spring Bean的作用域 .singleton [单例] eg:<bean id="personService" class="com.yinger.ser ...
- Spring bean的作用域以及生命周期
一.request与session的区别 request简介 request范围较小一些,只是一个请求. request对象的生命周期是针对一个客户端(说确切点就是一个浏览器应用程序)的一次请求,当请 ...
- spring bean 的作用域之间有什么区别
spring bean 的作用域之间有什么区别? spring容器中的bean可以分为五个范围.所有范围的名称都是说明的, 1.singleton:这种bean范围是默认的,这种范围确保不管接受到多个 ...
- spring bean 的作用域
spring bean 的作用域: 1.单例(singleton):默认是单例模式,也就是说不管给定的bean被注入到其他bean多少次,注入的都是同一个实例. 2.原型(prototype):每次注 ...
- Spring bean的作用域和生命周期
bean的作用域 1.singleton,prototype, web环境下:request,session,gloab session 2.通过scope="" 来进行配置 3. ...
- [跟我学spring][Bean的作用域]
Bean的作用域 什么是作用域呢?即“scope”,在面向对象程序设计中一般指对象或变量之间的可见范围.而在Spring容器中是指其创建的Bean对象相对于其他Bean对象的请求可见范围. Sprin ...
- Spring Bean的作用域类型
Bean的作用域类型 singleton :在Spring IOC容器中仅存在一个Bean实例,Bean以单实例的方式存在; prototype :每次从容器中调用Bean时,都返回一个新的实例,即每 ...
- spring bean的作用域和自动装配
1 Bean的作用域 l singleton单列:整个容器中只有一个对象实例,每次去访问都是访问同一个对象 默认是单列 l prototype原型: 每次获取bean都产生一个新的对象,比如Ac ...
- Spring Bean Scope (作用域)
singleton: 单例模式,针对每个spring容器,只有一个该类的实例被管理,每次调用此实例都是同一个对象被返回,所以适用于无状态bean.默认情况下,singleton作为spring容器中b ...
- Spring Bean的作用域以及lookup-method标签的使用
Spring Framework支持五种作用域,如下图所示: singleton:表示一个容器中只会存在一个bean实例,无论在多少个其他bean里面依赖singleton bean,整个容器都只会存 ...
随机推荐
- 转:SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)
转:https://www.cnblogs.com/zyw-205520/p/4771253.html 1.基本概念 1.1.Spring Spring是一个开源框架,Spring是于2003 年 ...
- halcon保存带有region的图片算子
显示带区域的图片除了可以用dev_display挨个显示外再截图,还可以通过一个算子来实现这一功能 这个算子是:dump_window_image.(其实就是截图) 这个算子的意思是把WindowHa ...
- 一、初始Object-C
一.OC概述 特点: 1没有包得概念 2关键字以@开头 3.拓展名 .m 二.第一个OC类 1,分为2个文件..m和.h文件 2. .m文件用来实现类 .h用来定义声明类 .h文件中得写法 //@i ...
- 前端css样式及选择器
标题: 1.scc概述 2.行内样式 3.内接样式 4.外接样式(链接式) 推荐使用 5.外接样式(导入式) 6.嵌套规则 7.css选择器 1.scc(Cascading Style Shee ...
- BZOJ1491: [NOI2007]社交网络(Floyd 最短路计数)
Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 2343 Solved: 1266[Submit][Status][Discuss] Descripti ...
- js、jquery中全局替换replace
str.replace(/需要替换的/g,"新字符串") //此处使用正则表达式
- Nginx的编译安装及服务启动脚本
1.解决依赖关系 编译安装nginx需要事先需要安装开发包组"Development Tools"和 "Development Libraries".同时,还需 ...
- GNU汇编 伪指令
伪指令 本身并没有所对应的机器码 它只是在编译的时候起作用,或者转换为其他的实际指令来运行 global ascii byte word data equ align @ 下面的例子是在数据段存放数据 ...
- MARK 一条关于Linux 运维方面个人向收藏网址
吴钧泽博客 https://wujunze.com/archives.html Linux运维笔记 https://blog.linuxeye.cn/ Linux中文网 http://www.ppze ...
- scrapy--matplotlib
昨天晚上看了一些关于保存文件的相关资料,早早的睡了,白天根据网上查找的资料,自己再捡起来.弄了一上午就爬取出来了,开心!!!好吧,让我们开始 老规矩,先上图.大家也赶快行动起来 分类文件: 文件内co ...