在Spring IoC 中 Bean之间的依赖被称之为 依赖注入(Dependecy Injection,DI)
依赖注入使用的注解为 @Autowired 他会根据属性的类型,找到对应的Bean 进行注入。
当同类型的bean有多个时,会通过名称进行选择,如果还是选择不出来会报错。
Exception in thread "main" org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'bussinessPerson': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire field: private com.didispace.service.Animal com.didispace.service.impl.BussinessPerson.animal; nested exception is org.springframework.beans.factory.NoUniqueBeanDefinitionException: No qualifying bean of type [com.didispace.service.Animal] is defined: expected single matching bean but found 2: cat,dog
要消除歧义 可以使用 @Primary ,@Quelifier
@Primary 是修改优先权的注解,需要用哪个Bean 就在哪个Bean上加@Primary。
有些时候有很多Bean上都有@Primary 这就又不满足了。
这时可以将@Autowired,@Qualifier 结合使用。
这实际上是调用BeanFactory 中,的如下方法
<T> T getBean(String name , Class<T> requiredType) throws BeansException;
例如 :实现 animal 的有dog,cat 两个类;在具体调用的时候,可以按如下方式标注
@Autowried
@Qualifier("dog")
private Animal animal = null;
上面这些方法都是基于默认的无参构造方法的注入。但有些清空 类只有一个有参构造函数
那上述方法就不能在使用了。为了满足这个功能,可以对构造方法的参数进行注入。看文档有
示例如下:
package com.didispace.service.impl;
import com.didispace.service.Animal;
import com.didispace.service.Person;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;
@Component
public class BussinessPerson implements Person {
private Animal animal = null;
public BussinessPerson(@Autowired @Qualifier("dog") Animal animal){
this.animal =animal;
}
@Override
public void service() {
this.animal.use();
}
@Override
public void setAnimal(Animal animal) {
this.animal = animal;
}
}
上述代码中@Autowired 报:autowired not applicable to parameter
autowired not applicable to parameter
的错误。。不知为啥。。
知道的大神请指点。。