Spring-03 依赖注入(DI)
Spring-03 依赖注入(DI)
依赖注入(DI)
- 依赖注入(Dependency Injection,DI)。
- 依赖 : 指Bean对象的创建依赖于容器,Bean对象的依赖资源。
- 注入 : 指Bean对象所依赖的资源,由容器来设置和装配。
1.构造器注入
这个是本博客文章Spring-02
中的案例
2.Set方式注入
2.1 实体类
public class Address {
private String address;
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}
public class DataTest {
private String name;
private Address address;
private String[] books;
private List<String> hobbys;
private Map<String,String> card;
private Set<String> games;
private String wife;
private Properties info;
public void setName(String name) {
this.name = name;
}
public void setAddress(Address address) {
this.address = address;
}
public void setBooks(String[] books) {
this.books = books;
}
public void setHobbys(List<String> hobbys) {
this.hobbys = hobbys;
}
public void setCard(Map<String, String> card) {
this.card = card;
}
public void setGames(Set<String> games) {
this.games = games;
}
public void setWife(String wife) {
this.wife = wife;
}
public void setInfo(Properties info) {
this.info = info;
}
public void show(){
System.out.println("name="+ name
+ ",address="+ address.getAddress()
+ ",books="
);
for (String book:books){
System.out.print("<<"+book+">>\t");
}
System.out.println("\n爱好:"+hobbys);
System.out.println("card:"+card);
System.out.println("games:"+games);
System.out.println("wife:"+wife);
System.out.println("info:"+info);
}
}
2.2 常量注入
<bean id="DataTest" class="pojo.DataTest">
<property name="name" value="zc"></property>
</bean>
2.3 Bean注入
<bean id="address" class="pojo.Address">
<property name="address" value="河南"/>
</bean>
<bean id="DataTest" class="pojo.DataTest">
<property name="address" ref="address"/>
</bean>
2.4 数组注入
<bean id="DataTest" class="pojo.DataTest">
<property name="books">
<array>
<value>西游记</value>
<value>三体</value>
<value>老人与海</value>
</array>
</property>
</bean>
2.5 List注入
<bean id="DataTest" class="pojo.DataTest">
<property name="hobbys">
<list>
<value>听歌</value>
<value>看电影</value>
<value>爬山</value>
</list>
</property>
</bean>
2.6 Map注入
<bean id="DataTest" class="pojo.DataTest">
<property name="card">
<map>
<entry key="中国邮政" value="1000"/>
<entry key="建设" value="2000"/>
</map>
</property>
</bean>
2.7 set注入
<bean id="DataTest" class="pojo.DataTest">
<property name="games">
<set>
<value>AOA</value>
<value>BOB</value>
<value>COC</value>
</set>
</property>
</bean>
2.8 Null注入
<bean id="DataTest" class="pojo.DataTest">
<property name="wife" >
<null/>
</property>
</bean>
2.9 Properties注入
<bean id="DataTest" class="pojo.DataTest">
<property name="info">
<props>
<prop key="driver">123456</prop>
<prop key="url">123456</prop>
<prop key="username">123465</prop>
<prop key="password">123456</prop>
</props>
</property>
</bean>
2.10 测试
@Test
public void Test(){
ApplicationContext context = new ClassPathXmlApplicationContext("bean.xml");
DataTest dataTest = (DataTest) context.getBean("DataTest");
dataTest.show();
}
3.拓展方式注入
3.1 P命名空间注入
头文件中加入约束文件:在配置文件头部
xmlns:p="http://www.springframework.org/schema/p"
注入
<bean id="user" class="pojo.User" p:name="zc" p:age="20"/>
3.2 C命名空间注入
头文件中加入约束文件:在配置文件头部
xmlns:c="http://www.springframework.org/schema/c"
注入
<bean id="user" class="pojo.User" c:name="zc" c:age="20"/>
这个时候会爆红
,因为缺少有参构造器
,这个方式也就是构造器注入
3.3 测试
@Test
public void Test1(){
ApplicationContext context = new ClassPathXmlApplicationContext("bean.xml");
User user = (User) context.getBean("user");
System.out.println(user);
}
Bean的作用域
作用域 | 描述 |
---|---|
singleton | 在spring IoC容器仅存在一个Bean实例,Bean以单例方式存在,bean作用域范围的默认值。 |
prototype | 每次从容器中调用Bean时,都返回一个新的实例,即每次调用getBean()时,相当于执行newXxxBean()。 |
request | 每次HTTP请求都会创建一个新的Bean,该作用域仅适用于web的Spring WebApplicationContext环境。 |
session | 同一个HTTP Session共享一个Bean,不同Session使用不同的Bean。该作用域仅适用于web的Spring WebApplicationContext环境。 |
application | 限定一个Bean的作用域为ServletContext 的生命周期。该作用域仅适用于web的Spring WebApplicationContext环境。 |
几种作用域中,request
、session
作用域仅在基于web的应用中使用,只能用在基于web的Spring ApplicationContext环境。
1.Singleton
当一个bean的作用域为Singleton,那么Spring IoC容器中只会存在一个共享的bean实例,并且所有对bean的请求,只要id与该bean定义相匹配,则只会返回bean的同一实例。Singleton是单例类型,就是在创建起容器时就同时自动创建了一个bean的对象,不管你是否使用,他都存在了,每次获取到的对象都是同一个对象。注意,Singleton作用域是Spring中的缺省作用域。要在XML中将bean定义成singleton,可以这样配置:
<bean id="ServiceImpl" class="cn.csdn.service.ServiceImpl" scope="singleton">
2.Prototype
当一个bean的作用域为Prototype,表示一个bean定义对应多个对象实例。Prototype作用域的bean会导致在每次对该bean请求(将其注入到另一个bean中,或者以程序的方式调用容器的getBean()方法)时都会创建一个新的bean实例。Prototype是原型类型,它在我们创建容器的时候并没有实例化,而是当我们获取bean的时候才会去创建一个对象,而且我们每次获取到的对象都不是同一个对象。根据经验,对有状态的bean应该使用prototype作用域,而对无状态的bean则应该使用singleton作用域。在XML中将bean定义成prototype,可以这样配置:
<bean id="account" class="com.foo.DefaultAccount" scope="prototype"/>
或者
<bean id="account" class="com.foo.DefaultAccount" singleton="false"/>
3.Request
当一个bean的作用域为Request,表示在一次HTTP请求中,一个bean定义对应一个实例;即每个HTTP请求都会有各自的bean实例,它们依据某个bean定义创建而成。该作用域仅在基于web的Spring ApplicationContext情形下有效。考虑下面bean定义:
<bean id="loginAction" class=cn.csdn.LoginAction" scope="request"/>
针对每次HTTP请求,Spring容器会根据loginAction bean的定义创建一个全新的LoginAction bean实例,且该loginAction bean实例仅在当前HTTP request内有效,因此可以根据需要放心的更改所建实例的内部状态,而其他请求中根据loginAction bean定义创建的实例,将不会看到这些特定于某个请求的状态变化。当处理请求结束,request作用域的bean实例将被销毁。
4.Session
当一个bean的作用域为Session,表示在一个HTTP Session中,一个bean定义对应一个实例。该作用域仅在基于web的Spring ApplicationContext情形下有效。考虑下面bean定义:
<bean id="userPreferences" class="com.foo.UserPreferences" scope="session"/>
针对某个HTTP Session,Spring容器会根据userPreferences bean定义创建一个全新的userPreferences bean实例,且该userPreferences bean仅在当前HTTP Session内有效。与request作用域一样,可以根据需要放心的更改所创建实例的内部状态,而别的HTTP Session中根据userPreferences创建的实例,将不会看到这些特定于某个HTTP Session的状态变化。当HTTP Session最终被废弃的时候,在该HTTP Session作用域内的bean也会被废弃掉。