1. 实例的注入方式

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

  • 属性注入

  • set 方法注入

  • 构造方法注入

我们分别来看下。

1.1 属性注入

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

@Service

publicclassBService{

@Autowired

AService aService;

//…

}

这里是使用 @Autowired 注解注入。另外也有 @Resource 以及 @Inject 等注解,都可以实现注入。想学习交流HashMap,nginx、dubbo、Spring MVC,分布式、高性能高可用、MySQL,redis、jvm、多线程、netty、kafka、的加尉xin(同英):1253431195 扩列获取java进阶资料学习,无工作经验不要加哦!

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

不推荐属性注入!

原因我们后面讨论。

1.2 set 方法注入

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

@Service

publicclassBService{

AService aService;

@Autowired

publicvoidsetaService(AService aService){

this.aService = aService;

}

}

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

1.3 构造方法注入

构造方法注入方式如下:

@Service

publicclassAService{

BService bService;

@Autowired

publicAService(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 一下这个类的对象,那么相关的依赖无法完成注入。想学习交流HashMap,nginx、dubbo、Spring MVC,分布式、高性能高可用、MySQL,redis、jvm、多线程、netty、kafka、的加尉xin(同英):1253431195 扩列获取java进阶资料学习,无工作经验不要加哦!

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

3. 小结

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

终于!我找到程序员爱穿卫衣的原因了

全公司电脑Alt键被抠掉,就为防员工摸鱼……

第一次拆Macbook,手有点抖…

深夜里,程序员最喜欢去的网站竟然是 …

Spring 的三种注入方式,到底哪种注入方式最佳?相关推荐

  1. 输入法注入源码_将注入进行到底:利用Mono注入C#游戏脚本

    本文作者01dTan9,首发于三叶草小组博客:http://blog.sycsec.com/   致力于引领每一位对windows安全感兴趣的萌新,希望让萌新能够对Windows有初步的了解.笔者的文 ...

  2. mysql有多少种日志_MySQL到底有多少种日志类型必须我们记住的!

    MySQL中有六种日志文件,分别是:重做日志(redo log).回滚日志(undo log).二进制日志(binlog).错误日志(errorlog).慢查询日志(slow query log).一 ...

  3. 扯一把 Spring 的三种注入方式,到底哪种注入方式最佳?

    循环依赖这个问题,按理说我们在日常的程序设计中应该避免,其实这个本来也是能够避免的.不过由于总总原因,我们可能还是会遇到一些循环依赖的问题,特别是在面试的过程中,面试考察循环依赖,主要是想考察候选人对 ...

  4. Spring的三种注入方式(为什么推荐构造器注入?)

    Spring的三种注入方式 一.属性注入 @Resource和@Autowired的区别 为什么尽量使用 @Resource? 二.setter 注入 三.构造器注入 具体可以看看Spring官网 为 ...

  5. Spring 的三种注入方式?

    1. 实例的注入方式 首先来看看 Spring 中的实例该如何注入,总结起来,无非三种: 属性注入 set 方法注入 构造方法注入 我们分别来看下. 1.1 属性注入 属性注入是大家最为常见也是使用最 ...

  6. 依赖注入的三种方式_一起学Spring之三种注入方式及集合类型注入

    本文主要讲解Spring开发中三种不同的注入方式,以及集合数据类型的注入,仅供学习分享使用,如有不足之处,还请指正. 概述 Spring的注入方式一共有三种,如下所示: 通过set属性进行注入,即通过 ...

  7. 【闲谈】论Spring的三种依赖注入方式

    知识点科普: IOC和DI:IOC是控制反转,DI是依赖注入.DI是行为,而IOC是实现这一行为的容器. 循环依赖:指类与类之间互相依赖的情况,比如有类A和类B,类A中依赖类B,类B中依赖类A,由此导 ...

  8. (转)Spring的三种实例化Bean的方式

    http://blog.csdn.net/yerenyuan_pku/article/details/52832793 Spring提供了三种实例化Bean的方式. 使用类构造器实例化. <be ...

  9. Spring框架学习教程,详解Spring注入bean的几种方式

    首先,要学习Spring中的Bean的注入方式,就要先了解什么是依赖注入. 依赖注入是指:让调用类对某一接口的实现类的实现类的依赖关系由第三方注入,以此来消除调用类对某一接口实现类的依赖. Sprin ...

最新文章

  1. 明朝是中国历史上最有骨气的王朝?【ZZ】
  2. Gallery 之滑动速度的问题
  3. Leetcode 98. 验证二叉搜索树 解题思路及C++实现
  4. saber软件安装后怎么打开_教程:新《Beat Saber》mod安装工具已推出
  5. VSCode+BeetleX.VueHost开发Vue应用
  6. KMP算法(快速模式匹配)
  7. map的几种遍历方法
  8. linux镜像文件的rpm,REDHAT安装镜像里的RPM文件02
  9. 如何在 Mac 上管理用于锁定备忘录的密码?
  10. 令人眼前一亮的下拉式终端 Tilda Guake
  11. jsp购物车和mysql_jsp购物车的代码和数据库
  12. 计算机专业电脑内存,电脑内存大小是否和速度有关?
  13. 公众号内测算法推荐引争议,却有小号因此阅读增长20倍
  14. 我的世界服务器无限背包,我的世界无限背包存档
  15. c语言常用几进制,C语言中你知道有哪些进制吗?
  16. 20210416 word插入题录却有图片嵌入word
  17. Windows同一网络下实现文件互传
  18. 战争磨盘九: 战争潜力
  19. 回想2020,仿佛就在昨天
  20. UESTC_方老师的分身 II CDOJ 915

热门文章

  1. C语言ASCII表与字符
  2. 在线计算机网页打不开了,网络正常网页打不开怎么办
  3. 声学特征(三) pitch
  4. git中查看全部分支的命令
  5. dofilter在java中_FilterChain doFilter中的java.lang.NullPointerException方法
  6. 各地区收入差距不平等、基尼系数、省级层面(分城镇和乡村)
  7. 微信小程序实例--洗衣小程序开发经验分享
  8. 2021年烟花爆竹储存找解析及专业培训历年考试错题集锦
  9. python嵌套是什么意思_python中的嵌套字典是什么意思?
  10. 【控制理论】用ADRC控制倒立摆