Spring DI依赖注入

一、依赖注入介绍

    spring动态的向某个对象提供它所需要的其他对象。这一点是通过DI(Dependency Injection,依赖注入)来实现的。比如对象A需要操作数据库,以前我们总是要在A中自己编写代码来获得一个Connection对象,有了 spring我们就只需要告诉spring,A中需要一个Connection,至于这个Connection怎么构造,何时构造,A不需要知道。在系统运行时,spring会在适当的时候制造一个Connection,然后像打针一样,注射到A当中,这样就完成了对各个对象之间关系的控制。A需要依赖 Connection才能正常运行,而这个Connection是由spring注入到A中的,依赖注入的名字就这么来的。那么DI是如何实现的呢? Java 1.3之后一个重要特征是反射(reflection),它允许程序在运行的时候动态的生成对象、执行对象的方法、改变对象的属性,spring就是通过反射来实现注入的。

  简单来说什么是依赖注入,就是给属性赋值(包括基本数据类型和引用数据类型)。

二、依赖注入的方式

(1)构造器注入

    过将@Autowired注解放在构造器上来完成构造器注入,默认构造器参数通过类型自动装配.

<bean id="accountService" class="com.buba.service.impl.AccountServiceImpl">
    <constructor-arg name="name" value="mys"></constructor-arg>
    <constructor-arg name="age" value="21"></constructor-arg>
    <constructor-arg name="time" ref="now"></constructor-arg>
</bean>
@Service
public class BookServiceImpl implements BookService{
	
	private BookMapper bookMapper;
	
	@Autowired
	public BookServiceImpl(BookMapper bookMapper) {
		this.bookMapper=bookMapper;
	}

}

    构造器注入的方式,能够保证注入的组件不可变,并且确保需要的依赖不为空。此外,构造器注入的依赖总是能够在返回客户端(组件)代码的时候保证完全初始化的状态。

2.接口注入

@Service
public class BookServiceImpl implements BookService{

	@Autowired
	private BookMapper bookMapper;

}

3.setter注入

    通过<property>标签

<bean id="book" class="com.buba.pojo.Book"
		init-method="myInit" destroy-method="myDestroy" scope="singleton">
		<property name="bid" value="1"></property>
		<property name="bname" value="冰菓"></property>
	</bean>
@Service
public class BookServiceImpl implements BookService{
	
	private BookMapper bookMapper;
	
	@Autowired
	public void setBookMapper(BookMapper bookMapper) {
		this.bookMapper = bookMapper;
	}
	
	public BookMapper getBookMapper() {
		return bookMapper;
	}

}

    setter的方式能用让类在之后重新配置或者重新注入。

三、Spring向对象属性注入集合类型

    创建一个实体类对象,用于演示数组、集合、Properties注入方式。

package com.buba.pojo;

import lombok.Data;

import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.Set;

@Data
public class Book {
    private String[] array;
    private List<String> list;
    private Set<String> set;
    private Map<String,Object> map;
    private Properties properties;
}

    applicationContext.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">

    <bean id="book" class="com.buba.pojo.Book">
        <property name="array">
            <array>
                <value>平凡的世界</value>
                <value>三体</value>
            </array>
        </property>
        <property name="list">
            <list>
                <value>简爱</value>
                <value>活着</value>
            </list>
        </property>
        <property name="set">
            <set>
                <value>呐喊</value>
                <value>百年孤独</value>
            </set>
        </property>
        <property name="map">
            <map>
                <entry key="1" value="老人与海"></entry>
                <entry key="2" value="挪威的森林"></entry>
            </map>
        </property>
        <property name="properties">
            <props>
                <prop key="driver">com.mysql.cj.jdbc.Driver</prop>
                <prop key="url">jdbc:mysql://localhost:3306/test</prop>
                <prop key="username">root</prop>
                <prop key="password">root</prop>
            </props>
        </property>
    </bean>
</beans>

    执行测试:

package com.buba;

import com.buba.pojo.Book;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Test {
    @org.junit.Test
    public void test(){
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
        Book book = context.getBean(Book.class);
        System.out.println(book);
    }
}

四、自动装配

(1)@Autowired

    @Autowired的自动装配,默认是根据类型注入,可以用于构造器、接口、方法注入。且必须有一个Bean候选者注入,默认required=true,如果允许出现0个Bean候选者需要设置属性“required=false”,“required”属性含义和@Required一样,只是@Required只适用于基于XML配置的setter注入方式,只能打在setting方法上。可以通过@Qualifier("名称")注解来指定名称装配

(2)@Resource

    @Resource注解可以标注在字段或属性的setter方法上,但它默认按名称装配。名称可以通过@Resource的name属性指定,当注解标注在字段上,即默认取字段的名称作为bean名称寻找依赖对象,当注解标注在属性的setter方法上,即默认取属性名作为bean名称寻找依赖对象。

如果本文对您有很大的帮助,还请点赞关注一下。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

游王子og

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

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

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

打赏作者

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

抵扣说明:

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

余额充值