当前位置: 首页 > news >正文

为什么spring默认采用单例bean

概 述

熟悉 Spring开发的朋友都知道 Spring 提供了 5种 scope,分别是:

  1. singleton: 单例模式,当spring创建applicationContext容器的时候,spring会欲初始化所有的该作用域实例,加上lazy-init就可以避免预处理;
  2. prototype:原型模式,每次通过getBean获取该bean就会新产生一个实例,创建后spring将不再对其管理;
    (下面是在web项目下才用到的)
  3. request:搞web的大家都应该明白request的域了吧,就是每次请求都新产生一个实例,和prototype不同就是创建后,接下来的管理,spring依然在监听;
  4. session: 每次会话,同上;
  5. global session: 全局的web域,类似于servlet中的application。

如下图是官方文档上的截图,感兴趣的朋友可以进去看看这五种分别有什么不同。今天要介绍的是这五种中的前两种,也是 Spring最初提供的 bean scopesingleton 和 prototype

Spring 官方文档介绍如下图:

单例bean与原型bean的区别

如果一个 bean被声明为单例的时候,在处理多次请求的时候在 Spring 容器里只实例化出一个bean,后续的请求都公用这个对象,这个对象会保存在一个map里面。当有请求来的时候会先从 缓存(map) 里查看有没有,有的话直接使用这个对象,没有的话才实例化一个新的对象,所以这是个单例的。但是对于 原型(prototypebean 来说当每次请求来的时候直接实例化新的bean,没有缓存以及从缓存查的过程。

1、画图分析

2、源码分析

生成 bean时先判断单例的还是原型的

如果是单例的则先尝试从缓存里获取,没有在新创建

3、结论:

  • 单例的 bean只有第一次创建新的 bean 后面都会复用该 bean,所以不会频繁创建对象。
  • 原型的 bean每次都会新创建

单例bean的优势

由于不会每次都新创建新对象所以有一下几个性能上的优势:

  1. 减少了新生成实例的消耗 新生成实例消耗包括两方面,第一,Spring会通过反射或者 cglib来生成 bean实例,这都是耗性能的操作,其次给对象分配内存也会涉及复杂算法
  2. 减少jvm垃圾回收 由于不会给每个请求都新生成bean实例,所以自然回收的对象少了
  3. 可以快速获取到 bean 因为单例的获取bean操作除了第一次生成之外其余的都是从缓存里获取的,所以很快

单例bean的劣势

单例的 bean一个很大的劣势就是他不能做到线程安全!!!由于所有请求都共享一个 bean实例,所以这个 bean要是有状态的一个 bean的话可能在并发场景下出现问题,而原型的 bean则不会有这样问题(但也有例外,比如他被单例 bean依赖),因为给每个请求都新创建实例。

相关文章:

为什么spring默认采用单例bean

概 述 熟悉 Spring开发的朋友都知道 Spring 提供了 5种 scope,分别是: singleton: 单例模式,当spring创建applicationContext容器的时候,spring会欲初始化所有的该作用域实例,加上lazy-init就可以避免预处理&#xf…...

Redisson分布式锁学习

之前工作中一直使用redis来实现分布式锁,但是最近项目使用了云弹性,机器会涉及到扩缩容,涉及到优雅停机的问题,普通的redis分布锁,一般使用时会设置锁的时间,但是如果在加锁期间 JVM异常重启等发生会导致分…...

Metabase:简单快捷的商业智能与数据分析工具 | 开源日报 No.61

moby/moby Stars: 66.8k License: Apache-2.0 Moby 是一个由 Docker 创建的开源项目,旨在实现和加速软件容器化。它提供了工具包组件的“乐高集”,可以将它们组装成基于容器的自定义系统的框架。组件包括容器生成工具、容器注册表、业务流程工具、运行时…...

【无标题】高流量大并发Linux TCP性能调优

最近在使用jmeter做压测,当jmeter的并发量高的时候发现jmeter服务器一直报错Cannot assign requested address, 查看了一下发现系统中存在大量处于TIME_WAIT状态的tcp端口 netstat -n | awk ‘/^tcp/ {S[$NF]} END {for(a in S) print a, S[a]}’ TIME_W…...

优雅的用户体验:微信小程序中的多步骤表单引导

前言 在微信小程序中,实现一个多步骤表单引导界面既可以提供清晰的任务指引,又可以增加用户体验的互动性。本文将探讨如何使用微信小程序的特性,构建一个流程引导界面,帮助用户一步步完成复杂任务。我们将从设计布局和样式开始&am…...

Kotlin中的委托、属性委托和延迟加载

委托模式是一种常用的设计模式,用于将某个对象的责任委托给另一个对象来处理。在Kotlin中,委托可以通过关键字by来实现,主要分为类委托和属性委托两种形式。此外,Kotlin还提供了延迟加载的功能,可以在需要时才进行初始…...

轻松合并Excel工作表:Java批量操作优化技巧

摘要:本文由葡萄城技术团队于CSDN原创并首发。转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。 前言 在Excel中设计表单时,我们经常需要对收集的信息进行统计分析。例如&a…...

计算机网络_网络层概述

4.1 网络层概述 4.1.1 一.分组转发和路由选择 网络层的主要任务就是将分组从源主机经过多个网络和多段链路传输到目的主机,可以将该任务划分为分组转发和路由选择两种重要的功能。 注释:A发送到B,从1端口进入. 如何得知是从2还是从3中转发出去呢?--------->这…...

自然语言处理---Transformer机制详解之GPT2模型介绍

1 GPT2的架构 从模型架构上看, GPT2并没有特别新颖的架构, 它和只带有解码器模块的Transformer很像. 所谓语言模型, 作用就是根据已有句子的一部分, 来预测下一个单词会是什么. 现实应用中大家最熟悉的一个语言模型应用, 就是智能手机上的输入法, 它可以根据当前输入的内容智…...

ChatGPT 即将诞生一周年,OpenAI 将有大动作

图片来源:由无界AI生成 下个月就是 ChatGPT 一周年纪念日。OpenAI 正在谋划新的大动作。可以肯定地说,自诞生以来,ChatGPT 就为 OpenAI 提供了不可阻挡的增长动力。 01 营收超预期,OpenAI 缓了一口气 据 The Information 报道&…...

jenkins 原理篇——pipeline流水线 声明式语法详解

大家好,我是蓝胖子,相信大家平时项目中或多或少都有用到jenkins,它的piepeline模式能够对项目的发布流程进行编排,优化部署效率,减少错误的发生,如何去写一个pipeline脚本呢,今天我们就来简单看…...

在ESP32-Arduino开发中添加其它Arduino库

目录 前言 原理说明 操作步骤 下载Bounce 安装Bounce 将下载的文件夹(压缩包需要解压)移动到components/arduino/libraries路径下,并重命名为Bounce2 查看添加库里所有的源文件位置 在arduino的CMakeList.txt里添加库源文件 使用Bounce 前言 乐鑫官方的es…...

CAN总线测试——CAN一致性之物理层

CAN一致性物理层测试项 1.最小通讯电压测试2.最大通讯电压测试3.显性位/隐性位输出电压测试4.信号跳变沿测试5. 地偏移6. 终端电阻 1.最小通讯电压测试 2.最大通讯电压测试 3.显性位/隐性位输出电压测试 4.信号跳变沿测试 5. 地偏移 6. 终端电阻...

macrodata数据集在Python统计建模和计量经济学中的应用

目录 一、数据介绍二、应用三、statsmodels 统计模块四、使用 statsmodels 统计模块分析 macrodata.csv 数据集参考 一、数据介绍 macrodata.csv是一个示例数据集,通常用于统计分析和计量经济学中的教育和训练目的。这个数据集通常包括以下列: year&am…...

【C++进阶(九)】C++多态深度剖析

💓博主CSDN主页:杭电码农-NEO💓   ⏩专栏分类:C从入门到精通⏪   🚚代码仓库:NEO的学习日记🚚   🌹关注我🫵带你学习C   🔝🔝 多态 1. 前言2. 多态的概念以及定义3. 多态的实…...

第二节——Vue 基本介绍

一、MV*的理解 1、概念 在计算机编程领域,MV*(也称为MVC、MVP、MVVM等)是一种用于组织和设计应用程序结构的模式。这些模式旨在实现应用程序的解耦、可维护性和可扩展性。MV代表着Model-View-(表示控制器或视图模型等其他组件&a…...

基于ResNet34的花朵分类

一.数据集准备 新建一个项目文件夹ResNet,并在里面建立data_set文件夹用来保存数据集,在data_set文件夹下创建新文件夹"flower_data",点击链接下载花分类数据集https://storage.googleapis.com/download.tensorflow.org/example_i…...

[计算机提升] 数据及相关概念

1.9 数据及相关概念 1.9.1 数据、信息 在Windows系统中,数据是指事实或信息的集合,可以是数字、文本、图像、声音等形式的内容。数据是计算机系统中处理和操作的基本元素,是信息的表现形式和载体。 与信息相比,数据的范围更广泛…...

第18章 SpringCloud生态(二)

18.11 说说你了解的负载均衡算法 难度:★★ 重点:★★★★ 白话解析 常用的负载均衡算法有: 1、轮询(Round Robin):说白了就是让服务器排好队,一个个轮着来调用;Ribbon默认采用该算法。 优点:实现起来简单; 缺点:服务器性能不一样的情况下,导致能力强的会经常空闲…...

【Android】BRVAH多布局实现

前言 基于3.0.4版本的BRVAH框架实现的 实现方法 1.创建多个不同类型的布局(步骤忽略) 2.创建数据实体类 数据类要实现【MultiItemEntity】接口 class MyMultiItemEntity(//获取布局类型override var itemType: Int,var tractorRes: Int? null,va…...

GLM-OCR实战:5分钟搭建本地文档解析工具,支持文本、表格、公式

GLM-OCR实战:5分钟搭建本地文档解析工具,支持文本、表格、公式 1. 工具概览:为什么选择GLM-OCR? 在日常工作中,我们经常需要处理各种文档——可能是扫描的合同、研究报告的截图,或是包含复杂表格和公式的…...

从个人网盘到企业网盘,教育行业的文件管理进化之路经历了什么?

教育数字化进程加速,培训机构和学校每天都在与大量的课程资料打交道——视频课件、教案文档、试卷题库、宣传素材。这些资料如何高效、安全地在老师之间流转?又如何分发到学生手中?个人网盘曾是许多机构的临时选择,但随着数据安全…...

STL迭代器:核心概念与实战指南

迭代器基础概念迭代器是STL的核心组件之一,提供了一种统一的方式来访问容器中的元素。迭代器类似于指针,可以指向容器中的某个元素,并支持解引用、递增等操作。迭代器分为五种类型:输入迭代器、输出迭代器、前向迭代器、双向迭代器…...

KirikiriTools:视觉小说游戏资源处理的终极开源解决方案

KirikiriTools:视觉小说游戏资源处理的终极开源解决方案 【免费下载链接】KirikiriTools Tools for the Kirikiri visual novel engine 项目地址: https://gitcode.com/gh_mirrors/ki/KirikiriTools KirikiriTools是一款专为Kirikiri视觉小说引擎设计的开源工…...

从 “存得下” 到 “算得快”:工业物联网需要新一代时序数据平台

工业物联网领域,为什么数据库“只存数据”已经不够了? 以前,大多数工业企业在谈数据库时,关注点还非常集中:能不能把数据存下来?能不能扛住设备数量?写入吞吐够不够?于是&#xff0…...

CS146S课程解析:LLM上限就是开发者的上限

第 6 周:AI 测试与安全 安全编码在 AI 时代变得更加重要。本周覆盖 SAST、DAST、漏洞检测、AI 生成的测试用例,以及如何用 Semgrep 等工具进行安全扫描。 第 7 周:现代软件支持 AI 代码审查、智能文档生成、调试辅助。如何建立对 AI 生成代码…...

StructBERT开源大模型部署教程:WebUI访问权限控制(Basic Auth)安全加固

StructBERT开源大模型部署教程:WebUI访问权限控制(Basic Auth)安全加固 1. 项目概述与安全需求 StructBERT是一个基于百度开源技术的高精度中文句子相似度计算模型,能够准确判断两个中文句子在语义上的相似程度。这个工具在文本…...

2026八大数据采集与数据服务工具深度测评:分级分类全解析

在数据驱动的时代,选择合适的数据工具如同挑选趁手的工具。为了帮你快速定位,本文将八款主流产品按 “数据采集工具(自助型)”和“数据服务商(成品/标注型)” 两大类别,再依据用户能力、团队规模…...

AIAgent不是微服务2.0:SITS2026圆桌用12组实测数据证伪主流架构方案,重构4层抽象模型

第一章:SITS2026圆桌:AIAgent架构的未来方向 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026圆桌讨论中,来自DeepMind、Anthropic、阿里通义实验室及MIT CSAIL的七位架构师一致指出:AIAgent正从“单体推理引擎”向“分…...

HexView 刷写脚本进阶:/FP与/FR参数在固件数据填充中的实战应用

1. 为什么需要精确控制固件数据填充? 在嵌入式开发中,我们经常遇到这样的场景:设备出厂前需要在特定内存区域写入校准数据,或者升级固件时要保留某些关键配置区域。这时候如果直接全盘擦写,就像用油漆桶泼墙——不仅会…...