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名称寻找依赖对象。
如果本文对您有很大的帮助,还请点赞关注一下。
还没有评论,来说两句吧...