Spring 的作用域

Spring Bean作用域解析

1.1 Bean的作用域
  Spring 3中为Bean定义了5中作用域,分别为singleton(单例)、prototype(原型)、request、session和global session,5种作用域说明如下:

singleton:单例模式,Spring IoC容器中只会存在一个共享的Bean实例,无论有多少个Bean引用它,始终指向同一对象。Singleton作用域是Spring中的缺省作用域,也可以显示的将Bean定义为singleton模式,配置为:

prototype:原型模式,每次通过Spring容器获取prototype定义的bean时,容器都将创建一个新的Bean实例,每个Bean实例都有自己的属性和状态,而singleton全局只有一个对象。根据经验,对有状态的bean使用prototype作用域,而对无状态的bean使用singleton作用域。
request:在一次Http请求中,容器会返回该Bean的同一实例。而对不同的Http请求则会产生新的Bean,而且该bean仅在当前Http Request内有效。
,针对每一次Http请求,Spring容器根据该bean的定义创建一个全新的实例,且该实例仅在当前Http请求内有效,而其它请求无法看到当前请求中状态的变化,当当前Http请求结束,该bean实例也将会被销毁。
session:在一次Http Session中,容器会返回该Bean的同一实例。而对不同的Session请求则会创建新的实例,该bean实例仅在当前Session内有效。
,同Http请求相同,每一次session请求创建新的实例,而不同的实例之间不共享属性,且实例仅在自己的session请求内有效,请求结束,则实例将被销毁。
global Session:在一个全局的Http Session中,容器会返回该Bean的同一个实例,仅在使用portlet context时有效。

<think> 嗯,用户想了解Spring作用域的相关信息,看起来他对Spring框架的基础概念有一定了解。之前系统指令要求使用中文回答并规范数学公式格式,不过这个问题主要涉及技术概念,不太需要数学表达式。 用户提供的三个引用内容其实已经覆盖了核心知识点:引用1提到作用域可扩展的特性,引用2列举了四种标准作用域,引用3详细解释了单例模式。需要把这些信息整合成系统的讲解。 注意到引用3里有个细节容易忽略——单例模式的作用范围是同一个JVM实例。这个点很重要,很多开发者误以为单例是全局唯一的,实际在集群环境中不同JVM会有多个实例。 用户可能是中级Java开发者,正在学习Spring框架。应该强调实际开发中最关键的三个作用域:单例(性能最优)、原型(需要状态隔离时使用)、请求/会话(Web场景)。特别是要提醒单例模式下避免使用实例变量,这是常见的踩坑点。 在整理回答时,考虑先定义作用域概念,再用表格对比不同类型,最后给出选型建议。对于自定义作用域部分,用户当前可能不需要深入实现细节,但应该提一句扩展性作为知识拓展。 相关问题设计要层层递进:先问核心区别(基础),再问线程安全(进阶),最后到自定义实现(高级)。这样无论用户是什么水平都能找到切入点。 </think> 以下是关于Spring Bean作用域的详细介绍,整合了核心概念和实际应用要点: ### 一、核心作用域类型 | 作用域 | 生命周期特征 | 适用场景 | |----------------|-----------------------------------------------------------------------------|----------------------------------| | **Singleton** | 整个IoC容器中仅存在**单个实例**(默认作用域)<br>✅ 容器启动时创建(懒加载可配置) | 无状态服务、工具类、数据库连接池 | | **Prototype** | 每次获取Bean时创建**新实例**<br>⛔ 容器不管理完整生命周期(需自行销毁) | 需要维护状态的对象(如购物车) | | **Request** | 每个HTTP请求创建**独立实例**<br>🌐 请求结束时销毁(仅Web环境有效) | 请求级别数据封装(如表单对象) | | **Session** | 每个用户会话创建**独立实例**<br>🔑 会话过期时销毁(仅Web环境有效) | 用户会话数据(如登录凭证) | | **Application**| ServletContext级别共享**单例**<br>🚀 生命周期与ServletContext一致 | 全局缓存、共享资源 | ### 二、关键特性详解 1. **Singleton模式注意事项** ```xml <!-- 显式声明单例(默认可省略) --> <bean id="service" class="com.example.ServiceImpl" scope="singleton"/> <!-- 懒加载配置(延迟初始化) --> <bean id="lazyService" class="com.example.LazyService" lazy-init="true"/> ``` - 单例Bean需保证**线程安全**,避免使用非静态成员变量存储状态[^3] - 与设计模式中的单例区别:Spring单例是**容器级单例**(非JVM级),多容器环境下仍可能存在多个实例 2. **Prototype模式特性** ```java // 每次getBean()调用生成新对象 ApplicationContext ctx = ... PrototypeBean p1 = ctx.getBean(PrototypeBean.class); PrototypeBean p2 = ctx.getBean(PrototypeBean.class); // p1 != p2 ``` - **内存泄漏风险**:容器只负责初始化,不负责销毁,需通过`@PreDestroy`或实现`DisposableBean`手动清理资源 3. **Web相关作用域** - Request/Session作用域需添加**监听器配置**(web.xml): ```xml <listener> <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class> </listener> ``` - 注解驱动配置(推荐): ```java @Bean @Scope(value = WebApplicationContext.SCOPE_SESSION, proxyMode = ScopedProxyMode.TARGET_CLASS) public UserPreferences userPreferences() { ... } ``` `proxyMode`解决作用域Bean注入单例Bean时的代理问题[^2] ### 三、自定义作用域(扩展机制) 1. **实现步骤** ```java // 1. 实现Scope接口 public class CustomScope implements Scope { @Override public Object get(String name, ObjectFactory<?> objectFactory) { ... } // 2. 注册到容器 @Bean public static CustomScopeConfigurer customScope() { CustomScopeConfigurer configurer = new CustomScopeConfigurer(); configurer.addScope("custom", new CustomScope()); return configurer; } } ``` 2. **应用场景** - 线程级作用域(ThreadScope) - 集群环境下的分布式作用域 - 特定业务维度的对象复用(如租户隔离)[^1] ### 四、选型建议 | 考量维度 | 优先选择的作用域 | |---------------|----------------| | 性能要求高 | Singleton | | 需维护状态 | Prototype | | Web请求数据封装 | Request | | 用户会话数据 | Session | | 全局共享资源 | Application | > **原则**:在满足业务需求的前提下,优先选用单例作用域以优化资源利用率[^3]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值