news 2026/5/11 6:15:53

为什么 Spring 和 IDEA 都不推荐使用 @Autowired 注解?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
为什么 Spring 和 IDEA 都不推荐使用 @Autowired 注解?

大家在使用IDEA开发的时候有没有注意到过一个提示,在字段上使用Spring的依赖注入注解@Autowired后会出现如下警告

Field injection is not recommended (字段注入是不被推荐的)

但是使用@Resource却不会出现此提示

网上文章大部分都是介绍两者的区别,没有提到为什么,当时想了好久想出了可能的原因,今天来总结一下

Spring常见的DI方式

  • 构造器注入:利用构造方法的参数注入依赖
  • Setter注入:调用Setter的方法注入依赖
  • 字段注入:在字段上使用@Autowired/Resource注解

@Autowired VS @Resource

事实上,他们的基本功能都是通过注解实现依赖注入,只不过@AutowiredSpring定义的,而@ResourceJSR-250定义的。大致功能基本相同,但是还有一些细节不同:

  • 依赖识别方式@Autowired默认是byType可以使用@Qualifier指定Name,@Resource默认ByName如果找不到则ByType
  • 适用对象@Autowired可以对构造器、方法、参数、字段使用,@Resource只能对方法、字段使用
  • 提供方@AutowiredSpring提供的,@ResourceJSR-250提供的

基于 Spring Boot + MyBatis Plus + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能

  • 项目地址:https://github.com/YunaiV/ruoyi-vue-pro
  • 视频教程:https://doc.iocoder.cn/video/

各种DI方式的优缺点

参考Spring官方文档,建议了如下的使用场景:

  • 构造器注入强依赖性(即必须使用此依赖),不变性(各依赖不会经常变动)
  • Setter注入可选(没有此依赖也可以工作),可变(依赖会经常变动)
  • Field注入:大多数情况下尽量少使用字段注入,一定要使用的话,@Resource相对@Autowired对IoC容器的耦合更低

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能

  • 项目地址:https://github.com/YunaiV/yudao-cloud
  • 视频教程:https://doc.iocoder.cn/video/
  • 不能像构造器那样注入不可变的对象
  • 依赖对外部不可见,外界可以看到构造器和setter,但无法看到私有字段,自然无法了解所需依赖
  • 会导致组件与IoC容器紧耦合(这是最重要的原因,离开了IoC容器去使用组件,在注入依赖时就会十分困难)
  • 导致单元测试也必须使用IoC容器,原因同上
  • 依赖过多时不够明显,比如我需要10个依赖,用构造器注入就会显得庞大,这时候应该考虑一下此组件是不是违反了单一职责原则

为什么IDEA只对@Autowired警告

Field注入虽然有很多缺点,但它的好处也不可忽略:那就是太方便了。使用构造器或者setter注入需要写更多业务无关的代码,十分麻烦,而字段注入大幅简化了它们。并且绝大多数情况下业务代码和框架就是强绑定的,完全松耦合只是一件理想上的事,牺牲了敏捷度去过度追求松耦合反而得不偿失。

那么问题来了,为什么IDEA只对@Autowired警告,却对@Resource视而不见呢?

个人认为,就像我们前面提到过的:@AutowiredSpring提供的,它是特定IoC提供的特定注解,这就导致了应用与框架的强绑定,一旦换用了其他的IoC框架,是不能够支持注入的。

@ResourceJSR-250提供的,它是Java标准,我们使用的IoC容器应当去兼容它,这样即使更换容器,也可以正常工作。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 15:24:56

学长亲荐!万众偏爱的AI论文工具 —— 千笔

你是否曾为论文选题发愁,反复修改却仍不满意?是否在查重、格式、文献整理上耗费大量时间却收效甚微?研究生阶段的论文写作,本就充满挑战,而千笔AI正是为解决这些痛点而生。它不仅能够高效生成结构清晰的论文内容&#…

作者头像 李华
网站建设 2026/5/8 15:30:28

三个线程如何按顺序打印ABC?

这篇文章分享一道非常不错的题目:三个线程按序打印ABC。很多读者朋友应该都觉得这道题目不难,这次给大家带来十二种做法,一定有你没有见过的新姿势。1. synchronizedwaitnotify说到同步,我们很容易就想到synchronized。线程间通信…

作者头像 李华
网站建设 2026/5/5 9:09:45

骨折分类数据集-医学影像分析-6717张X光片-适用于大学生毕业设计-支持目标检测与分类模型训练-完整标注信息-骨折检测与分类-医学影像分析研究者和开发者-推动骨折检测算法的研发与优化

骨折分类数据集:医学影像分析的完整资源 引言与背景 在现代医学影像分析领域,骨折检测与分类是骨科诊断的重要环节。随着深度学习技术的快速发展,基于X光片的骨折自动识别系统逐渐成为辅助临床诊断的关键工具。本数据集为医学影像分析研究者…

作者头像 李华
网站建设 2026/5/5 9:30:32

php 随机红包数生成

无论哪种实现方式,随机红包都要遵守几个核心约束(这是和单纯随机数最大的区别):总金额固定(比如 100 元分 10 个红包);每个红包金额非空(至少 0.01 元,避免分到 0&#x…

作者头像 李华
网站建设 2026/5/9 11:23:13

AI智能体:知识变现的“执行引擎“如何重塑行业规则|创客匠人

最近,一款名为Clawdbot的AI工具在科技圈引发热议。与传统AI聊天机器人不同,它不是在陪用户聊天,而是能直接调用用户的日历、邮箱、Notion等工具,执行实际任务。这背后反映了一个被忽视的行业真相:知识变现的关键不是内…

作者头像 李华
网站建设 2026/5/7 8:42:49

RBAC前端架构-06:使用localstorage及Vuex用户信息存储逻辑

1-文件调整 修改frontend-vue2\src\store\index.js,用于整体整合Vuex更简洁 import Vue from "vue"; import Vuex from "vuex";// 标签页管理模块 import tabs from "./modules/tabs"; // 用户信息管理模块 import user from ".…

作者头像 李华