Spring-IOC的依赖注入的三种方式-使用构造函数提供+使用set方法提供+使用注解提供+混合使用

本文详细介绍了Spring-IOC的依赖注入,包括构造函数注入、set方法注入和注解注入。依赖注入降低了程序间的耦合,Spring负责管理对象的依赖关系。此外,还讨论了注解注入的各种方式,如@Autowired、@Qualifier、@Resource和@Value,以及它们在不同场景下的应用。
摘要由CSDN通过智能技术生成

Spring-IOC的依赖注入

通过控制反转,把对象的创建交给了 spring,但是代码中不可能出现没有依赖的情况。ioc解耦只是降低他们的依赖关系,但不会消除。

例如:我们的业务层仍会调用持久层的方法。 那这种业务层和持久层的依赖关系,在使用 spring 之后,就让 spring 来维护了。 简单的说,就是坐等框架把持久层对象传入业务层,而不用我们自己去获取。

通过控制反转,把对象的创建交给了 spring,但是代码中不可能出现没有依赖的情况。ioc解耦只是降低他们的依赖关系,但不会消除。

例如:我们的业务层仍会调用持久层的方法。 那这种业务层和持久层的依赖关系,在使用 spring 之后,就让 spring 来维护了。 简单的说,就是坐等框架把持久层对象传入业务层,而不用我们自己去获取。

1.依赖注入

Dependency Injection。它是 spring 框架核心 ioc 的具体实现

IOC的作用:降低程序间的耦合(依赖关系)

依赖关系的管理:以后都交给spring来维护

在当前类需要用到其他类的对象,由spring为我们提供,我们只需要在配置文件中说明

依赖注入能注入的数据:有三类

基本类型和String,其他bean类型(在配置文件中或者注解配置过的bean),复杂类型/集合类型

注入的方式:有三种,前两种是xml配置注入,后面是注解

第一种:使用构造函数提供

第二种:使用set方法提供

第三种:使用注解提供

1构造函数注入

使用类中的构造函数,给成员变量赋值。注意,赋值的操作不是我们自己做的,而是通过配置的方式,让spring 框架来为我们注入。

  • 实现类
public class AccountServiceImpl implements AccountService {
   

    //如果是经常变化的数据,并不适用于注入的方式
    private String name;
    private Integer age;
    private Date birthday;

    public AccountServiceImpl(String name,Integer age,Date birthday){
   
        this.name = name;
        this.age = age;
        this.birthday = birthday;
    }

    public void  saveAccount(){
   
        System.out.println("service中的saveAccount方法执行了。。。"+name+","+age+","+birthday);
    }
}
  • bean.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd">

    <!-- spring中的依赖注入
        依赖注入:
            Dependency Injection
        IOC的作用:
            降低程序间的耦合(依赖关系)
        依赖关系的管理:
            以后都交给spring来维护
        在当前类需要用到其他类的对象,由spring为我们提供,我们只需要在配置文件中说明
        依赖关系的维护:
            就称之为依赖注入。
         依赖注入:
            能注入的数据:有三类
                基本类型和String
                其他bean类型(在配置文件中或者注解配置过的bean)
                复杂类型/集合类型
             注入的方式:有三种
                第一种:使用构造函数提供
                第二种:使用set方法提供
                第三种:使用注解提供(明天的内容)
     -->


    <!--构造函数注入:
        使用的标签:constructor-arg
        标签出现的位置:bean标签的内部
        标签中的属性
            type:用于指定要注入的数据的数据类型,该数据类型也是构造函数中某个或某些参数的类型
            index:用于指定要注入的数据给构造函数中指定索引位置的参数赋值。索引的位置是从0开始
            name:用于指定给构造函数中指定名称的参数赋值                                        常用的
            =============以上三个用于指定给构造函数中哪个参数赋值===============================
            value:用于提供基本类型和String类型的数据
            ref:用于指定其他的bean类型数据。它指的就是在spring的Ioc核心容器中出现过的bean对象

        优势:
            在获取bean对象时,注入数据是必须的操作,否则对象无法创建成功。
        弊端:
            改变了bean对象的实例化方式,使我们在创建对象时,如果用不到这些数据,也必须提供。
    -->
    <bean id="accountService" class="cn.lj.service.impl.AccountServiceImpl">
        <constructor-arg name="name" value="泰斯特"/>
        <constructor-arg name="age" value="18"/>
        <constructor-arg name="birthday" ref="now"/>
    </bean>

    <!-- 配置一个日期对象 -->
    <bean id="now" class="java.util.Date"/>
</beans>
2.set方法注入,更常用的方式
  • 对象类型和基本类型
public class AccountServiceImpl2 implements AccountService {
   
    private String name;
    private Integer age;
    private Date birthday;
    ....set,get
}
<!-- set方法注入                更常用的方式
        涉及的标签:property
        出现的位置:bean标签的内部
        标签的属性
            name:用于指定注入时所调用的set方法名称
            value:用于提供基本类型和String类型的数据
            ref:用于指定其他的bean类型数据。它指的就是在spring的Ioc核心容器中出现过的bean对象
        优势:
            创建对象时没有明确的限制,可以直接使用默认构造函数
        弊端:
            如果有某个成员必须有值,则获取对象是有可能set方法没有执行。
    -->
    <bean id="accountService2" class="cn.lj.service.impl.AccountServiceImpl2">
        <property name="name" value="TEST"/>
        <property name="age" value="21"/>
        <property name="birthday" ref="now"/>
    </bean>
  • 复杂类型的注入/集合类型的注入
public class AccountServiceImpl3 implements IAccountService {
   

    private String[] myStrs;
    private List<String> myList;
    private Set<String> mySet;
    private Map<String,String> myMap;
    private Properties myProps;

    public void setMyStrs(String[] myStrs) {
   
        this.myStrs = myStrs;
    }

    public void setMyList(List<String> myList) {
   
        this.myList = myList;
    }

    public void setMySet(Set<String> mySet) {
   
        this.mySet = mySet;
    }

    public void setMyMap(Map<String, String> myMap) {
   
        this.myMap = myMap;
    }

    public void setMyProps(Properties myProps) {
   
        this.myProps = myProps;
    }

    public void  saveAccount(){
   
        System.out.println(Arrays.toString(myStrs));
        System.out.println(myList)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

木子津

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

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

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

打赏作者

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

抵扣说明:

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

余额充值