共计 2154 个字符,预计需要花费 6 分钟才能阅读完成。
作者: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();
}
@Service
public class SvcA implements Svc {
@Override
public void sayHello() {System.out.println("hello, this is service A");
}
}
@Service
public class SvcB implements Svc {
@Override
public void sayHello() {System.out.println("hello, this is service B");
}
}
@Service
public class SvcC implements Svc {
@Override
public void sayHello() {System.out.println("hello, this is service C");
}
}
测试类:
@SpringBootTest
public 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)
,如果设置 required
为false
(默认为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
有两个重要的属性:name
和 type
,而 Spring 将@Resource
注解的 name
属性解析为 bean 的名字,而 type
属性则解析为 bean 的类型。
拆卸程序:
- 如果同时指定了
name
和type
,则从 Spring 上下文中找到惟一匹配的 bean 进行拆卸,找不到则抛出异样。 - 如果指定了
name
,则从上下文中查找名称(id)匹配的 bean 进行拆卸,找不到则抛出异样。 - 如果指定了
type
,则从上下文中找到类型匹配的惟一 bean 进行拆卸,找不到或是找到多个,都会抛出异样。 - 如果既没有指定
name
,又没有指定type
,则默认依照byName
形式进行拆卸;如果没有匹配,依照byType
h 进行拆卸。
近期热文举荐:
1.1,000+ 道 Java 面试题及答案整顿(2021 最新版)
2. 别在再满屏的 if/ else 了,试试策略模式,真香!!
3. 卧槽!Java 中的 xx ≠ null 是什么新语法?
4.Spring Boot 2.5 重磅公布,光明模式太炸了!
5.《Java 开发手册(嵩山版)》最新公布,速速下载!
感觉不错,别忘了顺手点赞 + 转发哦!