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

Spring boot 中的IOC容器对Bean的管理

Spring Boot 中 IOC 容器对 Bean 的管理,涵盖从容器启动到 Bean 的生命周期管理的全流程。


步骤 1:理解 Spring Boot 的容器启动

Spring Boot 的 IOC 容器基于 ApplicationContext,在应用启动时自动初始化。

  1. 入口类:通过 @SpringBootApplication 注解标记主类,启动容器。

    @SpringBootApplication
    public class MyApp {public static void main(String[] args) {SpringApplication.run(MyApp.class, args); // 启动容器}
    }
    
    • @SpringBootApplication 组合了三个核心注解:
      • @Configuration:标记为配置类。
      • @ComponentScan:自动扫描当前包及子包的组件(@Component, @Service 等)。
      • @EnableAutoConfiguration:启用 Spring Boot 的自动配置机制。
  2. 容器初始化

    • Spring Boot 启动时,创建 ApplicationContext(默认实现为 AnnotationConfigApplicationContext)。
    • 自动加载所有符合条件的 Bean(通过组件扫描和自动配置)。

步骤 2:注册 Bean 到容器

Bean 的注册主要有三种方式:

方式 1:组件扫描(自动注册)
  • 使用 @Component 及其派生注解标记类,容器自动扫描并注册为 Bean。
    @Service // 等价于 @Component,语义化标记为服务层
    public class UserService {// ...
    }
    
    • 其他派生注解:@Repository(DAO 层)、@Controller(Web 层)、@RestController
方式 2:Java 配置类(显式注册)
  • 定义 @Configuration 类,通过 @Bean 方法显式注册 Bean。
    @Configuration
    public class AppConfig {@Bean // 方法返回的对象会被注册为 Beanpublic DataSource dataSource() {return new HikariDataSource(); // 例如配置数据源}
    }
    
方式 3:自动配置(Spring Boot 特有)
  • Spring Boot 根据类路径依赖自动注册 Bean(如引入 spring-boot-starter-web 会自动配置 Tomcat、Spring MVC 相关 Bean)。
  • 原理:通过 META-INF/spring.factories 文件定义自动配置类,结合条件注解(如 @ConditionalOnClass)判断是否生效。

步骤 3:依赖注入(DI)

容器负责将依赖的 Bean 注入到需要它们的对象中。

注入方式
  1. 构造器注入(推荐)

    @Service
    public class OrderService {private final UserService userService;@Autowired // Spring 4.3+ 后,如果只有一个构造器,可省略 @Autowiredpublic OrderService(UserService userService) {this.userService = userService;}
    }
    
  2. Setter 注入

    public class MyService {private MyRepository repository;@Autowiredpublic void setRepository(MyRepository repository) {this.repository = repository;}
    }
    
  3. 字段注入(不推荐,仅用于简单场景)

    @Service
    public class MyService {@Autowiredprivate MyRepository repository;
    }
    

步骤 4:Bean 的作用域管理

通过 @Scope 注解指定 Bean 的作用域。

  1. 常用作用域
    • Singleton(默认):整个容器中只有一个实例(从始至终只有这一个)。
      @Bean
      @Scope("singleton")
      public MyBean myBean() { return new MyBean(); }
      
    • Prototype:每次请求创建新实例(每次使用的时候都需要重新创建这个bean)。
      @Bean
      @Scope("prototype")
      public MyBean myBean() { return new MyBean(); }
      
    • Request(Web 环境):每个 HTTP 请求一个实例。
    • Session(Web 环境):每个用户会话一个实例。

步骤 5:Bean 的生命周期管理

通过注解或接口控制 Bean 的初始化和销毁逻辑。

  1. 初始化方法

    @Component
    public class MyBean {@PostConstruct // 初始化完成后执行public void init() {System.out.println("Bean 初始化完成!");}
    }
    
  2. 销毁方法

    @Component
    public class MyBean {@PreDestroy // 容器关闭前执行public void cleanup() {System.out.println("Bean 即将销毁!");}
    }
    

步骤 6:高级配置与条件化 Bean

通过条件注解控制 Bean 的注册。

  1. 条件注解示例

    @Configuration
    public class MyConfig {@Bean@ConditionalOnClass(name = "com.example.ExternalLibrary") // 当类路径存在该类时注册public MyBean myBean() {return new MyBean();}@Bean@ConditionalOnMissingBean // 当容器中没有该类型 Bean 时注册public BackupBean backupBean() {return new BackupBean();}
    }
    
  2. Profile 环境隔离

    @Bean
    @Profile("dev") // 仅在 dev 环境下激活
    public DataSource devDataSource() {return new EmbeddedDatabaseBuilder().build();
    }
    

步骤 7:解决常见问题

  1. 循环依赖

    • 避免构造器注入循环,改用 Setter 或字段注入。
    • 重构代码,提取公共逻辑到第三方 Bean。
  2. Bean 冲突

    • 使用 @Primary 标记首选 Bean:
      @Bean
      @Primary
      public MyService primaryService() {return new PrimaryService();
      }
      
    • 使用 @Qualifier 指定具体 Bean:
      @Autowired
      @Qualifier("secondaryService")
      private MyService myService;
      

步骤 8:测试与验证

  1. 集成测试

    @SpringBootTest
    class UserServiceTest {@Autowiredprivate UserService userService; // 注入真实 Bean
    }
    
  2. 单元测试(Mock 依赖)

    @SpringBootTest
    class OrderServiceTest {@MockBeanprivate UserService userService; // 模拟 UserService@Autowiredprivate OrderService orderService;
    }
    

总结

通过以上步骤,Spring Boot 的 IOC 容器完成了以下核心任务:

  1. 启动容器:基于 @SpringBootApplicationApplicationContext
  2. 注册 Bean:通过组件扫描、配置类、自动配置。
  3. 依赖注入:构造器注入(推荐)、Setter 注入、字段注入。
  4. 作用域管理:单例、原型、请求、会话等。
  5. 生命周期控制@PostConstruct@PreDestroy
  6. 高级配置:条件化 Bean、Profile 隔离。
  7. 问题解决:循环依赖、Bean 冲突。
  8. 测试验证:集成测试与单元测试。

掌握这些步骤后,可以高效利用 Spring Boot 的 IOC 容器管理 Bean,构建松耦合、可维护的应用。

相关文章:

Spring boot 中的IOC容器对Bean的管理

Spring Boot 中 IOC 容器对 Bean 的管理,涵盖从容器启动到 Bean 的生命周期管理的全流程。 步骤 1:理解 Spring Boot 的容器启动 Spring Boot 的 IOC 容器基于 ApplicationContext,在应用启动时自动初始化。 入口类:通过 SpringB…...

ARINC818协议一些说明综述

关键术语 航空总线技术 光纤通道层次架构 光纤通道拓扑结构 FC-AV协议,架构,容器系统 ARINC818协议,容器 ADVB帧映射,帧格式 机载视频处理系统对视频数据进行实时处理和记录。 分辨率:1080p,4k,8k视频技术 FC-AV技术是…...

Turso:一个基于 libSQL的分布式数据库

Turso 是一个完全托管的数据库平台,支持在一个组织中创建高达数十万个数据库,并且可以复制到任何地点,包括你自己的服务器,以实现微秒级的访问延迟。你可以通过Turso CLI(命令行界面)管理群组、数据库和API…...

2025.5.4机器学习笔记:PINN文献阅读

2025.5.4周报 文献阅读题目信息摘要创新点网络架构实验结论不足以及展望 文献阅读 题目信息 题目: Physics-Informed Neural Network Approach for Solving the One-Dimensional Unsteady Shallow-Water Equations in Riverine Systems期刊: Journal o…...

一行命令打开iOS模拟器

要在 Mac 命令行打开 iPhone 15 Pro 模拟器,需满足已安装 Xcode 这一前提条件,以下是具体操作步骤: 步骤一:列出所有可用模拟器设备 打开终端(Terminal),输入并执行以下命令,用于列…...

java面向对象编程【基础篇】之基础语法

目录 🚀前言🌟构造器💯案例 🤔this关键字💯使用this调用本类中的属性💯使用this调用构造器💯this表示当前对象 🦜封装💯合理隐藏💯合理暴露 🐧实体…...

跑MPS产生委外采购申请(成品)

问题:跑MPS产生委外采购申请(成品),更改BOM和跑MRP,但物料需求清单中无新增物料复合膜的需求。截图如下: 解决方法:更改委外采购申请的批准日期为BOM的生效日和重新展开bom。 重新展开后&#x…...

[flutter]切换国内源(window)

如题,切换到国内源避免总是连不上google导致卡住的问题。 临时切换到国内: cmd set PUB_HOSTED_URLhttps://pub.flutter-io.cn set FLUTTER_STORAGE_BASE_URLhttps://storage.flutter-io.cnpower shell $env:PUB_HOSTED_URL "https://pub.flut…...

学习海康VisionMaster之顶点检测

一:进一步学习了 今天学习下VisionMaster中的顶点检测:可检测图像指定区域内的顶点,并输出顶点坐标等信息。该模块常用于检测目标物体的顶点 二:开始学习 1:什么是顶点检测? 一个不是很规则的物体需要检测…...

Vue2中常用的核心函数(选项和生命周期钩子)的完整示例及总结

以下是Vue2中常用的核心函数(选项和生命周期钩子)的完整示例及总结: 1. 实例选项函数 data 初始化组件数据 new Vue({el: #app,data() {return {message: Hello Vue!};} });methods 定义组件方法 new Vue({el: #app,data() {return { c…...

数据集-目标检测系列- F35 战斗机 检测数据集 F35 plane >> DataBall

数据集-目标检测系列- F35 战斗机 检测数据集 F35 plane >> DataBall DataBall 助力快速掌握数据集的信息和使用方式。 贵在坚持! * 相关项目 1)数据集可视化项目:gitcode: https://gitcode.com/DataBall/DataBall-detections-100s…...

2025年3月AGI技术月评|技术突破重构数字世界底层逻辑

〔更多精彩AI内容,尽在 「魔方AI空间」 ,引领AIGC科技时代〕 本文作者:猫先生 ——当「无限照片」遇上「可控试穿」,我们正在见证怎样的智能革命? 被低估的进化:开源力量改写游戏规则 当巨头们在AGI赛道…...

【k8s】k8s是怎么实现自动扩缩的

Kubernetes 提供了多种自动扩缩容机制,主要包括 Pod 水平自动扩缩(HPA)、垂直 Pod 自动扩缩(VPA) 和 集群自动扩缩(Cluster Autoscaler)。以下是它们的实现原理和配置方法: 1. Pod …...

协作开发攻略:Git全面使用指南 — 引言

协作开发攻略:Git全面使用指南 — 引言 Git 是一种分布式版本控制系统,用于跟踪文件和目录的变更。它能帮助开发者有效管理代码版本,支持多人协作开发,方便代码合并与冲突解决,广泛应用于软件开发领域。 文中内容仅限技…...

【AI提示词】私人教练

提示说明 以专业且细致的方式帮助客户实现健康与健身目标,提升整体生活质量。 提示词 # Role: 私人教练## Profile - language: 中文 - description: 以专业且细致的方式帮助客户实现健康与健身目标,提升整体生活质量 - background: 具备丰富的健身经…...

【星海出品】Calico研究汇总

Calico项目由Tigera公司发起并主导开发 源码 https://github.com/projectcalico/calico?tabreadme-ov-file#-join-the-calico-community 简介 Tigera是一家专注于云原生安全的公司,于2016年成立,其核心产品包括开源的Calico项目以及商业版的Calico Ent…...

观成科技:摩诃草组织Spyder下载器流量特征分析

一、概述 自2023年以来,摩诃草组织频繁使用Spyder下载器下载远控木马,例如Remcos。观成安全研究团队对近几年的Spyder样本进行了深入研究,发现不同版本的样本在数据加密、流量模式等方面存在差异。基于此,我们对多个版本样本的通…...

中心极限定理(CLT)习题集 · 题目篇

中心极限定理(CLT)习题集 题目篇 共 18 题,覆盖经典 CLT、Lyapunov/Lindeberg 条件、Berry–Esseen 评估、 以及工程/数据科学应用与编程仿真。推荐先独立完成,再看《答案与解析篇》。 之前已经出过相关的知识点文章,…...

ITL和TTL线程间值的传递

InheritableThreadLocal InheritableThreadLocal 继承自 ThreadLocal,增加了父线程到子线程的值传递功能。当一个新线程被创建时,InheritableThreadLocal 会将父线程中 ThreadLocal 变量的值拷贝到子线程(浅拷贝),子线…...

Android学习总结之Room篇

一、Room 框架基础 1. 实体类(Entity) 实体类用于描述数据库表的结构。通过使用 Entity 注解,可以将一个 Java 类映射到数据库中的一张表。例如,以下是一个简单的 User 实体类: import androidx.room.Entity; impor…...

java IO流

一:概述 (1)IO (2)流 二:分类 (1)流向 (2)数据单位 (3)IO流角色 三:API (1)InputStream &#xff…...

STM32 串口USART

目录 常见的通信方式 串行通信和并行通信 全双工,半双工和单工通信 同步通信和异步通信 通信速率 常见的通信协议 串口基础知识 电平特性 串口传输协议 STM32F103的USART资源 端口引脚 数据寄存器单元 发送接收控制单元 实现串口发送 printf…...

数字IC后端项目典型问题之后端实战项目问题记录(2025.04.24)

今天给大家分享下近两天小编帮助学员解决的几个经典后端项目问题。希望能够对大家的学习和工作有所帮助。 Q1:在做a7top顶层物理验证Calibre LVS检查时提示NOT COMPARED,请问是什么原因? 我们在用calibre检查LVS后,其结果基本上就是以下三种…...

关于边缘计算盒子的外部接口保护

边缘计算盒子是一种基于边缘计算和人工智能技术的智能设备,它内置了灵活可配的多样化AI算法库,所以也被称为AI算法盒子或智能边缘分析一体机,可以将数据处理和分析的能力推至离数据源最近的边缘位置,提供高效的数据处理和实时响应…...

OCP考试需要注意什么?

一、OCP考试需要准备的资料 身份证件:携带有效的身份证件(如身份证、护照等),以便在考试当天进行身份验证。确保身份证件在考试当天仍然有效,并且与报名时使用的证件一致。 准考证:打印并携带准考证&…...

git Http改用户下载

用原先别人账号,无权下更新 http方式设置自己账号 例如 git fetch --all 提示没有权限从 http://192.168.1.2/gitlab/项目路径.git下载 git remote set-url origin http://your-username192.168.1.2/gitlab/项目路径.git your-username修改成自己的git账号 需要输入一个Tok…...

postgres 导出导入(基于数据库,模式,表)

在 PostgreSQL 中,导出和导入数据库、模式(schema)或表的数据可以使用多种工具和方法。以下是常用的命令和步骤,分别介绍如何导出和导入整个数据库、特定的模式以及单个表的数据。 一、导出数据 1. 使用 pg_dump 导出整个数据库…...

把dll模块注入到游戏进程的方法_挂起进程注入

一. 概述 挂起进程注入是指在创建进程的时候把运行状态设置为挂起,然后创建一个远程线程,来注入。挂起进程注入作为远线程注入的一个补充,可以在进程创建的时候就注入,从而注入时间较早,不宜被拦截。易知挂起进程注入的局限性也就是如果进程已经启动,那么这种注入方式就…...

TypeScript 开发实战:如何安全替换字符串中的关键字

在 TypeScript 开发中,我们经常需要处理字符串替换的场景。最近我在开发一个表达式解析功能时,遇到了一个有趣的挑战:如何将用户输入的简化数学表达式(如"sin")替换为标准形式(如"Math.sin&…...

ES6 模块化 与 CommonJS 的核心概念解析

以下是关于 ES6 模块化 与 CommonJS 的核心概念解析、知识点总结及使用场景说明: 1. ES6 模块化与 CommonJS 是什么? ES6 模块化(ECMAScript Modules, ESM) 定义:ES6 标准引入的模块系统,使用 import 和 …...

【踩坑记录】stm32 jlink程序烧录不进去

最近通过Jlink给STM32烧写程序时一直报错,但是换一个其他工程就可以烧录,对比了一下jink配置,发现是速率选太高了“SW Device”,将烧录速率调整到10MHz以下就可以了...

CS144 Lab 6 实战记录:构建 IP 路由器

1 实验背景与目标 在 CS144 的 Lab 6 中,我们需要在之前实现的 NetworkInterface(Lab 5)基础上构建一个完整的 IP 路由器。路由器的主要任务是根据路由表将接收到的 IP 数据报转发到正确的网络接口,并发送给正确的下一跳&#xf…...

AI与智能能源管理:如何通过AI优化能源分配和消耗?

引言:能源管理面临的新挑战 在“双碳”目标持续推进的背景下,能源管理已经不再是简单的节电节水问题,而是关乎可持续发展和企业长期竞争力的核心议题。无论是工业园区、写字楼,还是家庭用户,能源的使用正在变得越来越复…...

【蓝桥杯】产值调整

产值调整 题目描述 偏远的小镇上,三兄弟共同经营着一家小型矿业公司“兄弟矿业”。公司旗下有三座矿山:金矿、银矿和铜矿,它们的初始产值分别用非负整数 A A A、 B B B 和 C C C 表示。这些矿山的产出是小镇经济的核心,支撑着…...

使用Next.js构建单页面React应用

最近遇到一个问题 突然要一个单页面的项目 用惯了Next.js 而 create-react-app 又不推荐且不灵活 最终找发现Nextjs也支持单页面应用 以下是使用Next.js构建单页面React应用过程 1 正常创建项目 (我选择的是Pages Router 而非 AppRoute) 2 修改配置文件 next.config.ts impor…...

Python字符串三剑客:len()、split()、join()深度解析

目录 一、len():字符串的"测谎仪" 二、split():字符串的"解剖刀" 参数解析: 实战场景: 三、join():字符串的"缝合怪" 性能优势: 实战案例: 高级技巧&…...

大模型是如何生成内容的?

大模型(如 GPT、Claude、LLaMA 等)生成内容的过程,其实就是一个 逐词预测上下文推理 的过程。我们可以把它想象成一个“超级自完成引擎”:每一步都在问自己—— “在目前上下文下,最合理的下一个词是什么?”…...

Python元组全面解析:从基础到高级应用指南

一、元组基础概念与核心特性 1.1 元组的本质定义 元组(Tuple)是Python中重要的不可变序列类型,由多个元素组成的有序集合。其核心特性表现在: 元素按插入顺序存储,支持索引访问所有元素存储在连续内存空间&#xff…...

Docker部署DeepSeek常见问题及解决方案

在使用Docker部署DeepSeek的过程中,许多开发者可能会遇到一些常见问题。本文整理了几个高频问题及其解决方案,帮助大家更顺利地完成部署。 镜像拉取失败 问题现象 执行 docker pull 命令时,提示超时或镜像不存在。 可能原因 1. 网络环境不稳定,导致连接Docker Hub失败…...

身份证实名认证接口数字时代的信任基石-node.js实名认证集成

在互联网深度渗透生活的当下,从线上购物、社交娱乐到金融理财、政务办理,每一次指尖的触碰都在虚拟世界中留下痕迹。身份证实名认证作为连接现实身份与网络身份的桥梁,正以其不可替代的作用,重塑着数字时代的信任体系。它不仅是保…...

多维时序 | LightGBM多变量时序预测(Matlab完整源码和数据,适合基础小白研究)

多维时序 | LightGBM多变量时序预测(Matlab完整源码和数据,适合基础小白研究) 目录 多维时序 | LightGBM多变量时序预测(Matlab完整源码和数据,适合基础小白研究)效果一览基本介绍程序设计参考资料 效果一览…...

强化学习(Reinforcement Learning, RL)和深度学习(Deep Learning, DL)

强化学习(Reinforcement Learning, RL)和深度学习(Deep Learning, DL)是人工智能领域两个重要的研究方向,虽然二者可以结合(如深度强化学习),但其核心思想、目标和应用场景存在本质区…...

图论---Prim堆优化(稀疏图)

题目通常会提示数据范围&#xff1a; 若 V ≤ 500&#xff0c;两种方法均可&#xff08;朴素Prim更稳&#xff09;。 若 V ≤ 1e5&#xff0c;必须用优先队列Prim vector 存图。 #include <iostream> #include <vector> #include <queue> #include <…...

【优秀三方库研读】【C++基础知识】odygrd/quill -- 折叠表达式

compute_encoded_size_and_cache_string_lengths 方法中这段代码是一个C的折叠表达式&#xff08;fold expression&#xff09;的应用&#xff0c;用于计算多个参数编码后的总大小。下面我将详细解释这段代码的每个部分&#xff0c;并说明为什么这样写。 代码如下&#xff1a; …...

优化Nginx的下载功能

缘起&#xff1a; 我购置了一台阿里云ECS&#xff0c;其EIP带宽3m/s&#xff0c;但是在其上的作为下载文件的服务器nginx提供的下载速度仅有几百KB。 分析&#xff1a; 既然没有达到带宽瓶颈&#xff0c;肯定存在优化的空间。浮现脑海的想法&#xff0c;nginx没有进行最佳配置…...

Vue3集成浏览器API实时语音识别

效果示例 用法 <!-- 浏览器语音识别 --> <BrowserSpeechRecognitionModal v-if"showModal" :isOpen"showModal" close"showModal false" confirm"handleRecognitionResult" />const showModal ref(false); const input…...

Python3 基础:函数定义与调用

Python3 基础&#xff1a;函数定义与调用 什么是函数&#xff1f;一、函数的定义二、函数的调用三、函数参数3.1位置参数3.2关键字参数3.3默认参数值3.4可变数量的参数args&#xff1a;接收任意数量的位置参数**kwargs&#xff1a;接收任意数量的关键字参数 3.5 综合使用各种参…...

Vue 2 的响应式 API 和 Vue 3 的组合式 API 的详细对比,从核心机制、使用方式、代码示例及优缺点展开

以下是 Vue 2 的响应式 API 和 Vue 3 的组合式 API 的详细对比&#xff0c;从核心机制、使用方式、代码示例及优缺点展开&#xff1a; 1. Vue 2 的响应式 API 核心机制 基于 Object.defineProperty&#xff1a; 通过劫持对象的 getter 和 setter 实现数据变化追踪。限制&…...

修改了Element UI中组件的样式,打包后样式丢失

修改了Element UI中组件的样式&#xff0c;在本地运行没有问题&#xff0c;但是打包到线上发现样式丢失&#xff08;样式全部不生效、或者有一部分生效&#xff0c;一部分不生效&#xff09;&#xff0c;问题在于css的加载顺序导致代码编译后样式被覆盖了&#xff0c; 解决办法…...

大模型工业化元年:GPT-5开启通用AI新纪元,中国技术如何破局?

过去一周&#xff0c;AI领域的焦点无疑是OpenAI发布的GPT-5预览版&#xff0c;以及全球大模型技术从实验室迈向工业化的关键转折。这场变革不仅标志着通用人工智能&#xff08;AGI&#xff09;的进一步逼近&#xff0c;更掀起了全球产业链的竞争与反思。本文将从技术突破、产业…...