作者:Richard_Yi\
起源:juejin.cn/post/6844904056230690824

本章的内容次要是想探讨咱们在进行Spring 开发过程当中,对于依赖注入的几个问题。感兴趣的读者能够先看下以下三点:

  • @Autowired, @Resource, @Inject 三个注解的区别
  • 当你在应用@Autowired时,是否有呈现过Field injection is not recommended的正告?你晓得这是为什么吗?
  • Spring 依赖注入有哪几种形式?官网是怎么倡议应用的呢?

如果你对上述问题都理解,那我集体感觉你的开发教训应该是不错的。如果你看到这三个问题很懵能够往下看。

上面咱们就顺次对上述问题进行解答,并且总结知识点。

@Autowired, @Resource, @Inject 三个注解的区别

Spring 反对应用@Autowired, @Resource, @Inject 三个注解进行依赖注入。上面来介绍一下这三个注解有什么区别。

举荐一个 Spring Boot 基础教程及实战示例:
https://github.com/javastacks...

@Autowired

@Autowired为Spring 框架提供的注解,须要导入包org.springframework.beans.factory.annotation.Autowired

这里先给出一个示例代码,不便解说阐明:

public interface Svc {    void sayHello();}@Servicepublic class SvcA implements Svc {    @Override    public void sayHello() {        System.out.println("hello, this is service A");    }}@Servicepublic class SvcB implements Svc {    @Override    public void sayHello() {        System.out.println("hello, this is service B");    }}@Servicepublic class SvcC implements Svc {    @Override    public void sayHello() {        System.out.println("hello, this is service C");    }}

测试类:

@SpringBootTestpublic class SimpleTest {    @Autowired    // @Qualifier("svcA")    Svc svc;    @Test    void rc() {        Assertions.assertNotNull(svc);        svc.sayHello();    }}

拆卸程序:

1.依照type在上下文中查找匹配的bean,查找type为Svc的bean

2.如果有多个bean,则依照name进行匹配

  • 如果有@Qualifier注解,则依照@Qualifier指定的name进行匹配,查找name为svcA的bean
  • 如果没有,则依照变量名进行匹配,查找name为svcA的bean

3.匹配不到,则报错。(@Autowired(required=false),如果设置requiredfalse(默认为true),则注入失败时不会抛出异样)

@Inject

在Spring 的环境下,@Inject@Autowired 是雷同的,因为它们的依赖注入都是应用AutowiredAnnotationBeanPostProcessor来解决的。

@Inject是 JSR-330 定义的标准,如果应用这种形式,切换到Guice也是能够的。

Guice 是 google 开源的轻量级 DI 框架

如果硬要说两个的区别,首先@Inject是Java EE包里的,在SE环境须要独自引入。另一个区别在于@Autowired能够设置required=false@Inject并没有这个属性。

@Resource

@Resource是JSR-250定义的注解。Spring 在 CommonAnnotationBeanPostProcessor实现了对JSR-250的注解的解决,其中就包含@Resource

@Resource有两个重要的属性:nametype,而Spring 将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。

拆卸程序:

  1. 如果同时指定了nametype,则从Spring上下文中找到惟一匹配的bean进行拆卸,找不到则抛出异样。
  2. 如果指定了name,则从上下文中查找名称(id)匹配的bean进行拆卸,找不到则抛出异样。
  3. 如果指定了type,则从上下文中找到类型匹配的惟一bean进行拆卸,找不到或是找到多个,都会抛出异样。
  4. 如果既没有指定name,又没有指定type,则默认依照byName形式进行拆卸;如果没有匹配,依照byTypeh进行拆卸。

近期热文举荐:

1.1,000+ 道 Java面试题及答案整顿(2021最新版)

2.别在再满屏的 if/ else 了,试试策略模式,真香!!

3.卧槽!Java 中的 xx ≠ null 是什么新语法?

4.Spring Boot 2.5 重磅公布,光明模式太炸了!

5.《Java开发手册(嵩山版)》最新公布,速速下载!

感觉不错,别忘了顺手点赞+转发哦!