news 2026/4/23 16:18:09

为什么 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/4/23 11:15:19

论文党必看!2026AI 写作工具全新榜单,效率直接封神

还在为论文选题秃头?为文献综述熬夜?为降重改到怀疑人生?2026 年 AI 论文写作工具已经进化到全流程闭环阶段,从选题到答辩一站式搞定,效率直接封神!本文实测 20 款主流工具,筛选出性价比天花板…

作者头像 李华
网站建设 2026/4/23 12:14:11

拖延症福音:AI论文写作软件,千笔ai写作 VS 万方智搜AI,自考党必备!

随着人工智能技术的迅猛迭代与普及,AI辅助写作工具已逐步渗透到高校学术写作场景中,成为专科生、本科生、研究生完成毕业论文不可或缺的辅助手段。越来越多面临毕业论文压力的学生,开始依赖各类AI工具简化写作流程、提升创作效率。但与此同时…

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

springboot地区特色农产品团购平台 小程序

目录系统概述核心功能技术架构创新点应用价值项目技术支持可定制开发之功能亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作系统概述 SpringBoot地区特色农产品团购平台小程序是一个基于SpringBoot框架开发的电商平台,专注于…

作者头像 李华
网站建设 2026/4/23 9:32:01

好写作AI:当你的研究伙伴是个“AI同事”——人机协作的甜蜜与界限

导语:如果你的实验室来了个24小时不眠、精通30门学科、还从不说“我要休假”的新同事想象一下这样的场景:凌晨三点,你卡在一个概念上,它秒回:“这个理论其实可以从三个角度突破...”你只提供了模糊想法,它整…

作者头像 李华
网站建设 2026/4/23 9:34:38

好写作AI:当模型章节写成“天书”,AI就是你的首席翻译官

导语:如果你的创新算法连导师都看不懂,那它可能真的“过于创新”了理工科同学的日常魔幻现实:实验室熬了三个月搞出的新模型,答辩时评委问:“所以你的创新点到底是?”明明算法效果提升了15%,写出…

作者头像 李华