Field injection is not recommended 警告的主要原因是:使用变量的依赖注入不被推荐。
@Autowired
private REListingRepository reListingRepository;
可能很多人都会使用上面代码来进行依赖注入,因为上面的代码最简单,也是可以用的,但有时候你会遇到 IJ 的提示。
原因和处理
这个代码与 Spring 的 Autowired 3 种类注入依赖有关。
变量注入
上面的写法就是变量注入,这是我们遇到警告提示的地方。
Set 方法注入
为了避免上面的警告,我们可以使用 Set 方法来进行注入。
使用 Set 方法的代码如下:
private REListingRepository reListingRepository;
@Autowired
public void setReListingRepository(REListingRepository reListingRepository) {
this.reListingRepository = reListingRepository;
}
构造器方法注入
另外的,我们还可以使用构造器的方法来进行注入。
上面的代码可以简化为:
private REListingRepository reListingRepository;
private TownRepository townRepository;
@Autowired
public TaxServiceImpl(REListingRepository reListingRepository, TownRepository townRepository) {
this.reListingRepository = reListingRepository;
this.townRepository = townRepository;
}
的构造器方法来进行注入。
IJ 快捷键
在 IDEA 中是可以使用快捷键的。
在代码的空白地方,使用快捷键 Alt + Insert。
在弹出的对话框中,你可以看到为你生成构造方法和 Setter 方法的快捷键。
然后选择需要的生成相应的方法即可,而不需要你再手动敲一次。
使用何种依赖注入
我们现在知道了 Spring 有 3 中依赖注入方式。那么我们应该使用何种依赖注入方式?
是使用: Constructor-based or setter-based DI
其实在官方里面已经有一个解释说明了:6. The IoC container
简单来说 Set 方法依赖注入中使用的依赖是可选的,选择依赖的意思是注入的依赖是可以为 NULL 的,当然你也可以在 Set 方法中通过添加 @Required 让依赖不为 NULL。
如果使用构造方法注入依赖的话,那么依赖是不能为 NULL 的。
变量方式注入应该尽量避免,使用set方式注入或者构造器注入,这两种方式的选择就要看这个类是强制依赖的话就用构造器方式,选择依赖的话就用set方法注入。
根据 Spring 官方的说法,如果注入的对象是 immutable objects (不可变对象)的话,依赖的注入是不能为 NULL 的。因此基于上面的示例和说法,Spring 官方是推荐使用构造方法来进行依赖注入,以便于针对不可变对象的注入。
唯一感觉不是非常好的就是代码比较长,看起来不太舒服。
不过使用 IEDA 可以在修改变量后重新使用快捷键生成构造方法。
https://www.ossez.com/t/spring-autowired-field-injection-is-not-recommended/13264/2