@Autowired的注入方式

本文深入探讨Spring框架中的依赖注入机制,包括被动注入与主动注入的区别,以及如何通过接口实现依赖的抽象化。文章还详细解释了按类型(bytype)和按名称(byname)的注入方式,并介绍了在存在多个实现类时,如何使用@Qualifier注解来精确指定注入的目标Bean。
摘要由CSDN通过智能技术生成

之前的文章依赖注入注入的是一个具体类的对象。但是这样就违背了依赖倒置的原则,如果我们要满足变化需要依赖一个抽象,而不是依赖一个具体。

public class BannerController {
	@Autowired
    private Diana diana;
}

首先,我们要把Diana抽象成一个接口

public interface ISkill {
    void r();
}
----------------------------------------------------------------------
@Component
public class Diana implements ISkill {
    public Diana() {
        System.out.println("Hello Diana");
    }
    public void r(){
        System.out.println("Diana R");
    }
}

@Autowired被动注入

bytype

public class BannerController {

    @Autowired
    private ISkill iSkill;

	@GetMapping("/test")
    public String test1() {
        iSkill.r();
        return "Hello test1";
    }

此时访问接口的结果为:
在这里插入图片描述
bytype是默认的注入方式,寻找实现了interface的Bean,适用于只有一个Bean实现了接口的情况。

byname

但是当再加入一个ISkill的实现类

@Component
public class Irelia implements ISkill {
    public Irelia() {
        System.out.println("Hello Irelia");
    }
    public void r(){
        System.out.println("Irelia R");
    }
}

当同时有两个类实现ISkill这个接口时,controller中再像之前那样注入就会报错
在这里插入图片描述
当把注入的代码改成:

	@Autowired
    private ISkill diana;

执行结果为:
在这里插入图片描述
当把注入的代码改成:

	@Autowired
    private ISkill irelia;

执行结果为:
在这里插入图片描述
在按类型注入失败的情况下,就会按字段的名字(byname)推断注入哪个Bean进来。这也体现了Spring约定大于配置的原则

结论:
bytype是默认的注入方式,Spring会到容器中寻找实现了interface的Bean
1.找不到任何一个bean => 报错
2.找到一个 => 直接注入
3.找到多个 => 并不一定会报错,按照字段名字推断选择哪个bean

@Autowired主动注入

当按类型匹配没有找到确定的Bean,按字段名匹配也没有找到确定的Bean就会报错。我们可以通过 @Qualifier指定bean的名字,主动选择要注入的Bean

 	@Autowired
    @Qualifier("irelia")
    private ISkill iSkill;

执行结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三毛村滴雪鱼粉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值