构造函数注入
1.xml
<packaging>jar</packaging>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.0.2.RELEASE</version>
</dependency>
</dependencies>
2.service,serviceImpl
/**
* 账户业务层的接口
*/
public interface IAccountService {
/**
* 模拟保存账户
*/
void saveAccount();
}
/**
* 账户的业务层实现类
*/
public class AccountServiceImpl implements IAccountService {
//如果是经常变化的数据,并不适用于注入的方式
private String name;
private Integer age;
private Date birthday;
/**
* 构造函数,初始化变量
* @param name
* @param age
* @param birthday
*/
public AccountServiceImpl(String name,Integer age, Date birthday){
this.name = name;
this.age = age;
this.birthday = birthday;
}
public void saveAccount(){
System.out.println("--------"+name+","+age+","+birthday);
}
}
<!--把对象的创建交给spring来管理-->
<!--id:获取时的而为一标志即起名, class:反射要创建的全限定类名-->
<!--spring中的依赖注入
依赖注入:
Dependency Injection
IOC作用:
降低程序间的耦合(依赖关系)
依赖关系的管理:
以后都交给spring来维护
在当前类需要用到其他类的对象,由spring为我们提供,我们只需要在配置文件中说明
依赖关系的维护:
就称为依赖注入
能注入的数据:有三类
基本类型和String
其他bean类型(在配置文件中或者注解配置过的bean)
复杂类型/集合类型
注入的方式:有三种
第一种:使用构造函数提供
第二种:使用set方法提供
第三种:使用注解提供
-->
3.bean.xml
<!--构造函数注入
使用的标签:constructor-arg
标签出现的位置:bean标签内部
标签中的属性
type:用于指定要注入的数据的数据类型,该数据类型也是构造函数中某个或某些参数的类型
index:用于指定要注入的数据给构造函数中指定索引位置的参数赋值,索引的位置是从0开始
name:用于指定给构造函数中指定名称的参数赋值(常用)
===================以上三个用于指定给构造函数中那个三叔赋值===================
value:用于提供基本类型和String类型的数据
ref:用于指定其他的bean类型数据,他指的就是在spring的Ioc核心容器中出现bean对象。
优势:在获取bean对象时,注入数据是必须的操作,否则对象无法创建成功
弊端:改变了bean对象的实例化方式,使我们在创建对象时,如果用不到这些数据也必须使用
-->
<!--此处会报错,因为此方法调用的是默认构造函数,此时已没有默认构造函数-->
<bean id="accountService" class="sise.cn.service.Impl.AccountServiceImpl">
<constructor-arg name="name" value="6ms"></constructor-arg>
<constructor-arg name="age" value="18"></constructor-arg>
<constructor-arg name="birthday" ref="now"></constructor-arg>
</bean>
<!--配置一个日期对象class="java.util.Date"在容器中创建一个date名为now-->
<bean id="now" class="java.util.Date"></bean>
</beans>
4表现层
/**
* 模拟一个表现层,用于调用业务层
*/
public class Client {
/**
* 获取spring的Ioc核心容器,并根据id获取对象
* @param args
*/
public static void main(String[] args) {
//1.获取核心容器对象
ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");//读取配置文件
//2.根据id即唯一标志获取Bean对象
//两种方式一个要强转一个不用
/* IAccountService as = (IAccountService)ac.getBean("accountService");//写唯一标志*/
IAccountService as = ac.getBean("accountDao", IAccountService.class);
as.saveAccount();
}
}
结果
--------6ms,18,Mon May 20 11:05:20 CST 2019
set方法注入(常用)
1.service,serviceImpl:用set方法
/**
* 账户业务层的接口
*/
public interface IAccountService {
/**
* 模拟保存账户
*/
void saveAccount();
}
/**
* 账户的业务层实现类
*/
public class AccountServiceImpl implements IAccountService {
//如果是经常变化的数据,并不适用于注入的方式
private String name;
private Integer age;
private Date birthday;
public void setName(String name) {
this.name = name;
}
public void setAge(Integer age) {
this.age = age;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
public void saveAccount(){
System.out.println("--------"+name+","+age+","+birthday);
}
}
2.bean.xml
<!--set方法注入
涉及的标签:property
出现的位置:bean标签的内部
标签的属性:
name:用于指定注入时所调用的set方法名称
value:用于提供基本类型和String类型的数据
ref:用于指定其他的bean类型数据,他指的就是在spring的Ioc核心容器中出现bean对象。
优势:
创建对象时没有明确的限制,可以直接使用默认构造函数
弊端:
如果有某个成员必须有值,则获取对象时set方法没有执行
-->
<bean id="accountService" class="sise.cn.service.Impl.AccountServiceImpl">
<property name="name" value="test"></property>
<property name="age" value="21"></property>
<property name="birthday" ref="now"></property>
</bean>
<!--配置一个日期对象class="java.util.Date"在容器中创建一个date名为now-->
<bean id="now" class="java.util.Date"></bean>
3.表现层
/**
* 模拟一个表现层,用于调用业务层
*/
public class Client {
/**
* 获取spring的Ioc核心容器,并根据id获取对象
* @param args
*/
public static void main(String[] args) {
//1.获取核心容器对象
ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");//读取配置文件
//2.根据id即唯一标志获取Bean对象
IAccountService as = ac.getBean("accountService", IAccountService.class);
as.saveAccount();
}
}
复杂类型注入(注入集合数据)
用set方法注入
1.service serviceImpl:
/**
账户业务层的接口
*/
public interface IAccountService {
/**
模拟保存账户
*/
void saveAccount();
}
**
* 账户的业务层实现类
*/
public class AccountServiceImpl 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);
System.out.println(myMap);
System.out.println(myProps);
System.out.println(mySet);
}
}
2.bean.xml
<!--复杂类型的注入,集合类型的注入
用于给list结构集合注入的标签
list arrays set
用于给map结构集合注入的标签
map props
结构相同,标签可以互换
-->
<bean id="accountService" class="sise.cn.service.Impl.AccountServiceImpl">
<property name="myStrs">
<array>
<value>aaaa</value>
<value>bbbb</value>
<value>cccc</value>
</array>
</property>
<property name="myList">
<list>
<value>aaaa</value>
<value>bbbb</value>
<value>cccc</value>
</list>
</property>
<property name="mySet">
<set>
<value>aaaa</value>
<value>bbbb</value>
<value>cccc</value>
</set>
</property>
<property name="myMap">
<map>
<entry key="testA" value="AAAA"></entry>
<entry key="testB">
<value>BBBB</value>
</entry>
</map>
</property>
<property name="myProps">
<props>
<prop key="testC">cccc</prop>
<prop key="testD">dddd</prop>
</props>
</property>
</bean>
3.表现层
/**
* 模拟一个表现层,用于调用业务层
*/
public class Client {
/**
* 获取spring的Ioc核心容器,并根据id获取对象
* @param args
*/
public static void main(String[] args) {
//1.获取核心容器对象
ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");//读取配置文件
//2.根据id即唯一标志获取Bean对象
IAccountService as = ac.getBean("accountService", IAccountService.class);
as.saveAccount();
}
}