前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Spring学习(二):Spring支持的5种Bean Scope

Spring学习(二):Spring支持的5种Bean Scope

作者头像
凯哥Java
发布2022-12-16 16:47:07
3550
发布2022-12-16 16:47:07
举报
文章被收录于专栏:凯哥Java凯哥Java

阅读目录:

阅读正文:

回到顶部

序言

Scope是定义Spring如何创建bean的实例的。Spring容器最初提供了两种bean的scope类型:singleton和prototype,但发布2.0以后,又引入了另外三种scope类型:request、session和global session,这三种只能在web 应用中才可以使用。

在创建bean的时候可以带上scope属性,scope有下面几种类型:

b35676f2365632072e63b29915c65073.png
b35676f2365632072e63b29915c65073.png

概念理解

Spring官方文档表示有如下5种类型:

b212100b1fa77a5554b22322aa7ab8c7.png
b212100b1fa77a5554b22322aa7ab8c7.png

singleton:

这是Spring默认的scope,表示Spring容器只创建唯一一个bean的实例,所有该对象的引用都共享这个实例,并且Spring在创建第一次后,会在Spring的IoC容器中缓存起来,之后不再创建,就是设计模式中的单例模式的形式。

并且对该bean的所有后续请求和引用都将返回该缓存中的对象实例。一般情况下,无状态的bean使用该scope。

prototype:

代表线程每次调用或请求这个bean都会创建一个新的实例。一般情况下,有状态的bean使用该scope。

request:

每次http请求将会有各自的bean实例,类似于prototype。 也就是说每个request作用域内的请求只创建一个实例。

session:

在一个http session中,一个bean定义对应一个bean实例。也就是说每个session作用域内的请求只创建一个实例。

global session:

在一个全局的http session中,一个bean定义对应一个bean实例。

但是,这个scope只在porlet的web应用程序中才有意义,它映射到porlet的global范围的session,如果普通的web应用使用了这个scope,容器会把它作为普通的session作用域的scope创建。

注: 再次说明spring的默认scope(bean作用域)是singleton

使用方式

创建bean的时候如何指定其作用域呢?

XML方式:

代码语言:javascript
复制
< bean  id = “accountService”  class = “com.foo.DefaultAccountService”  scope = “prototype” />

注解方式:

代码语言:javascript
复制
@Component@Scope("prototype")
public class User{
    …………
}

参考书籍:

Spring官网:https://docs.spring.io/spring/docs/3.0.0.M3/reference/html/ch04s04.html

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-11-02 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 序言
  • 概念理解
    • singleton:
      • prototype:
        • request:
          • session:
            • global session:
            • 使用方式
              • XML方式:
                • 注解方式:
                • 参考书籍:
                相关产品与服务
                容器服务
                腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档