Spring 的三种注入方式?

1. 实例的注入方式

首先来看看 Spring 中的实例该如何注入,总结起来,无非三种:

  • 属性注入

  • set 方法注入

  • 构造方法注入

我们分别来看下。

1.1 属性注入

属性注入是大家最为常见也是使用最多的一种注入方式了,代码如下:

@Service public?class?BService?{ ????@Autowired ????AService?aService; ????//... }

这里是使用@Autowired注解注入。另外也有@Resource以及@Inject等注解,都可以实现注入。

不过不知道小伙伴们有没有留意过,在 IDEA 里边,使用属性注入,会有一个警告:

不推荐属性注入!

原因我们后面讨论。

1.2 set 方法注入

set 方法注入太过于臃肿,实际上很少使用:

@Service public?class?BService?{ ????AService?aService; ????@Autowired ????public?void?setaService(AService?aService)?{ ????????this.aService?=?aService; ????} }

这代码看一眼都觉得难受,坚决不用。

1.3 构造方法注入

构造方法注入方式如下:

@Service public?class?AService?{ ????BService?bService; ????@Autowired ????public?AService(BService?bService)?{ ????????this.bService?=?bService; ????} }

如果类只有一个构造方法,那么@Autowired注解可以省略;如果类中有多个构造方法,那么需要添加上@Autowired来明确指定到底使用哪个构造方法。

2. 实例注入方式大 PK

上面给大家列出来了三种注入方式,那么三种注入方式各自有何区别呢?

结合 Spring 官方文档,我们来分析下。

松哥翻出了 12 年前的 Spring3.0 的文档(https://docs.spring.io/spring-framework/docs/3.0.x/reference/beans.html),里边有如下一段话:

我来简单翻译下(意译):

使用构造方法注入还是使用 set 方法注入?由于构造方法注入和 set 方法注入可以混合使用,因此,如果需要强制注入,我们可以使用构造方法注入的方式;如果是可选注入,则我们可以使用 set 方法注入的方式。当然,我们在 setter 上使用 @Required 注解可以让 set 方法注入也变为强制性注入。**Spring 团队通常提倡 setter 注入,因为当属性特别多的时候,构造方法看起来会特别臃肿,特别是当属性是可选的时(属性可选意味着没必要通过构造方法注入)。Setter 方法注入还有一个好处就是可以使该类的属性可以在以后重新配置或重新注入。**一些纯粹主义者喜欢基于构造函数的注入,这样意味着所有的属性都被初始化了,缺点则是对象变得不太适合重新配置和重新注入。另外在一些特殊的场景下,如一个第三方类要注入到 Spring 容器,但是该类没有提供 set 方法,那么此时你就只能使用构造方法注入了。

英文水平有限,大概翻译了下。小伙伴们重点看加粗部分,也就是说在 Spring3.0 时代,官方还是提倡 set 方法注入的。

不过从 Spring4.x 开始,官方就不推荐这种注入方式了,转而推荐构造器注入。

我们来看看 Spring4.x 的文档怎么说(https://docs.spring.io/spring-framework/docs/4.0.x/spring-framework-reference/htmlsingle/#beans-setter-injection):

这段内容我就不一一翻译了,大家重点看第二段第一句:

The Spring team generally advocates constructor injection

这句话就是说 Spring 团队倡导通过构造方法完成注入。才一个大版本更新,Spring 咋就变了呢?别急,人家也给出用构造方法注入的理由,第二段翻译一下大概是这个意思:

通过构造方法注入的方式,能够保证注入的组件不可变,并且能够确保需要的依赖不为空。此外,构造方法注入的依赖总是能够在返回客户端(组件)代码的时候保证完全初始化的状态。

上面这段话主要说了三件事:

  1. 依赖不可变:这个好理解,通过构造方法注入依赖,在对象创建的时候就要注入依赖,一旦对象创建成功,以后就只能使用注入的依赖而无法修改了,这就是依赖不可变(通过 set 方法注入将来还能通过 set 方法修改)。

  2. 依赖不为空:通过构造方法注入的时候,会自动检查注入的对象是否为空,如果为空,则注入失败;如果不为空,才会注入成功。

  3. 完全初始化:由于获取到了依赖对象(这个依赖对象是初始化之后的),并且调用了要初始化组件的构造方法,因此最终拿到的就是完全初始化的对象了。

在 Spring3.0 文档中,官方说如果构造方法注入的话,属性太多可能会让代码变得非常臃肿,那么在 4.0 文档中,官方对这个说法也做了一些订正:如果用构造方法注入的时候,参数过多以至于代码过于臃肿,那么此时你需要考虑这个类的设计是否合理,这个类是否参杂了太多的其他无关功能,这个类是否做到了单一职责。

好吧,你说的总是有理!

这是构造方法注入和 set 方法注入的问题,那么上面我们还提到不推荐属性注入,这又是咋回事呢?

属性注入其实有一个显而易见的缺点,那就是对于 IOC 容器以外的环境,除了使用反射来提供它需要的依赖之外,无法复用该实现类。因为该类没有提供该属性的 set 方法或者相应的构造方法来完成该属性的初始化。换言之,要是使用属性注入,那么你这个类就只能在 IOC 容器中使用,要是想自己 new 一下这个类的对象,那么相关的依赖无法完成注入。

以上分析都是根据 Spring 官方文档得来,日常开发应该还是属性注入较多,这个咱们不必纠结,代码该咋写还咋写,Spring 官方的态度了解一下即可,当然,如果项目允许,也不妨试试 Spring 推荐的代码规范。

3. 小结

好啦,今天就和小伙伴们随便扯扯 Spring 中的注入方式,希望对你有帮助~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1142278.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深度剖析ST7789初始化序列:适合初学的理解方式

点亮第一帧:拆解ST7789初始化背后的工程逻辑你有没有遇到过这样的场景?硬件接好了,代码烧进去了,LVGL界面也写得漂漂亮亮——结果屏幕一动不动,黑屏、白屏、花屏轮番上演。反复检查接线无误,SPI通信也有波形…

PDF-Extract-Kit实战案例:智能文档检索系统

PDF-Extract-Kit实战案例:智能文档检索系统 1. 引言 在科研、教育和企业办公场景中,PDF 文档作为知识传递的核心载体,往往包含大量结构化信息——如文字、表格、数学公式和图像。然而,传统方式难以高效提取这些内容并进行二次利…

BRAM在图像处理缓存中的实现:完整示例解析

BRAM在图像处理缓存中的实战设计:从原理到可综合代码你有没有遇到过这样的问题——明明FPGA的逻辑资源还很充裕,但图像处理流水线却频频卡顿?像素流断了、卷积核等数据、边缘检测结果延迟飙升……最终发现,瓶颈不在算法&#xff0…

HY-MT1.5性能对比:与Google翻译API实测数据

HY-MT1.5性能对比:与Google翻译API实测数据 在多语言交流日益频繁的今天,高质量、低延迟的机器翻译模型成为跨语言沟通的核心基础设施。近年来,随着大模型技术的快速发展,开源翻译模型逐渐具备了与商业API相媲美的能力。腾讯近期…

PDF智能提取工具箱实战:手写公式转LaTeX完整步骤

PDF智能提取工具箱实战:手写公式转LaTeX完整步骤 1. 引言:从扫描文档到结构化数据的智能化跃迁 在科研、教学和工程实践中,PDF文档中常包含大量手写或印刷体数学公式、表格和文本内容。传统方式下,将这些非结构化信息转化为可编…

基于深度学习 YOLOv8➕pyqt5的西红柿成熟度检测系统

基于深度学习 YOLOv8➕pyqt5的西红柿成熟度检测系统, 完整源码源文件已标注的数据集训练好的模型环境配置教程程序运行说明文档 可以替换自己训练的模型,实现检测目标自定义 blog.csdnimg.cn/direct/31c61653310648458126c961a01fd682.png) 以下文章及示…

PDF-Extract-Kit快速上手:10分钟完成第一个PDF解析项目

PDF-Extract-Kit快速上手:10分钟完成第一个PDF解析项目 1. 引言 在科研、教育和办公场景中,PDF文档常包含大量结构化信息——如公式、表格、图文混排内容。然而,传统方式难以高效提取这些元素,尤其是数学公式和复杂表格的数字化…

STM32CubeMX工业电机控制配置:完整指南

用STM32CubeMX打造工业级电机控制系统:从配置到实战的深度实践你有没有遇到过这样的场景?刚接手一个三相PMSM电机控制项目,硬件板子已经打好了,但PWM波形不对、电流采样总在噪声区、编码器读数跳变……调试几天都没找出问题。最后…

无人机培训PPT课件 多旋翼无人飞行培训无人机精灵培训PPT

无人机培训PPT课件 多旋翼无人飞行培训无人机精灵培训PPT 素材 一、课程内容概述 基础理论: 详细讲解无人机的定义、分类以及多旋翼无人机在整个无人机体系中的独特地位和特点。 让学员清晰了解无人机的基本概念,包括按照用途(如航拍、物流、…

HY-MT1.5边缘计算方案:离线环境翻译应用部署

HY-MT1.5边缘计算方案:离线环境翻译应用部署 在多语言交流日益频繁的今天,高质量、低延迟的翻译服务成为智能设备、跨境沟通和本地化应用的核心需求。然而,依赖云端API的传统翻译方案面临网络延迟、数据隐私和离线不可用等挑战。为此&#x…

基于STM32的rs485modbus协议源代码实现完整示例

基于STM32的RS485 Modbus通信实战:从硬件连接到代码落地在工业现场,你是否曾为多个传感器与控制器之间的布线复杂、通信不稳定而头疼?是否遇到过不同厂家设备因协议不兼容,导致系统集成困难?今天,我们来解决…

PDF-Extract-Kit入门教程:PDF元数据提取与分析

PDF-Extract-Kit入门教程:PDF元数据提取与分析 1. 引言 1.1 技术背景与学习目标 在数字化办公和学术研究中,PDF文档已成为信息传递的主要载体。然而,PDF的封闭性使得从中高效提取结构化数据(如文本、公式、表格)成为…

HY-MT1.5-1.8B模型裁剪:进一步减小体积的方法

HY-MT1.5-1.8B模型裁剪:进一步减小体积的方法 1. 背景与技术动机 随着大模型在翻译任务中的广泛应用,如何在保持高质量翻译能力的同时降低部署成本,成为工程落地的关键挑战。腾讯开源的混元翻译模型 HY-MT1.5 系列包含两个核心版本&#xf…

腾讯开源HY-MT1.5:模型量化压缩技术解析

腾讯开源HY-MT1.5:模型量化压缩技术解析 1. 技术背景与问题提出 近年来,随着大语言模型在自然语言处理任务中的广泛应用,翻译模型的性能不断提升。然而,高精度往往伴随着巨大的参数量和计算开销,导致模型难以在资源受…

HY-MT1.5-1.8B实战:低功耗设备部署方案

HY-MT1.5-1.8B实战:低功耗设备部署方案 1. 引言 随着多语言交流需求的快速增长,高质量、低延迟的翻译模型成为智能终端和边缘计算场景的核心组件。腾讯近期开源了混元翻译大模型1.5版本(HY-MT1.5),其中包含两个关键模…

STM32烧录必备:STLink驱动下载与配置实战案例

STM32烧录不翻车:STLink驱动安装与配置全实战指南 你有没有遇到过这样的场景? 新买了一块Nucleo开发板,兴冲冲插上USB线准备下载第一个“Hello World”程序,结果STM32CubeIDE弹出一串红字:“No target connected”。 …

HY-MT1.5-1.8B工业场景应用:设备手册实时翻译系统部署案例

HY-MT1.5-1.8B工业场景应用:设备手册实时翻译系统部署案例 1. 引言 1.1 工业场景中的多语言挑战 在全球化制造与跨国协作日益频繁的背景下,工业设备制造商和运维团队常常面临多语言技术文档的处理难题。设备手册、操作指南、维护说明等关键资料往往需要…

PDF-Extract-Kit实战案例:保险理赔自动化系统

PDF-Extract-Kit实战案例:保险理赔自动化系统 1. 引言 1.1 业务背景与痛点分析 在传统保险理赔流程中,大量依赖人工处理纸质或PDF格式的医疗单据、费用清单和诊断报告。某区域性保险公司年均处理超10万份理赔材料,其中80%为扫描件或非结构…

HY-MT1.5-1.8B量化部署指南:低资源环境运行方案

HY-MT1.5-1.8B量化部署指南:低资源环境运行方案 1. 引言 随着多语言交流需求的不断增长,高质量、低延迟的翻译模型成为智能硬件、边缘计算和实时通信场景中的关键技术。腾讯开源的混元翻译大模型 HY-MT1.5 系列,凭借其卓越的语言覆盖能力和翻…

PDF-Extract-Kit技术解析:文档结构理解算法演进

PDF-Extract-Kit技术解析:文档结构理解算法演进 1. 引言:从PDF解析困境到智能提取的跨越 1.1 行业背景与技术挑战 在科研、教育、出版和企业办公场景中,PDF作为标准文档格式承载了大量结构化信息。然而,传统PDF解析工具长期面临…