Bean 的作用域:
1.單例模式(Spring 默認機制)
scope=“singleton”
2.原型模式:每次從容器中 get 時,都會產生一個新對象
scope="prototype"
3. request、session、application,只能在 web 開發中使用
Bean 的自動裝配:
自動裝配是 Spring 滿足 bean 依賴的一種方式
Spring 會在上下文中自動尋找,并自動給 bean 裝配屬性
Spring 中有三種裝配的方式:
1.在 xml 中顯示配置
2.在 java 中顯示配置
3.隱式的自動裝配 bean
寫兩個類
寫個 Person 類,get/set 方法,toString() 方法
package com.demo.autowired;public class Person {private Cat cat;private Dog dog;private String name;public Cat getCat() {return cat;}public void setCat(Cat cat) {this.cat = cat;}public Dog getDog() {return dog;}public void setDog(Dog dog) {this.dog = dog;}public String getName() {return name;}public void setName(String name) {this.name = name;}@Overridepublic String toString() {return "Person{" +"cat=" + cat +", dog=" + dog +", name='" + name + '\'' +'}';}
}
beans.xml 文件:
ByName 自動裝配:autowire="byName"
會自動在容器上下文中查找和自己對象 set 方法后面的值對應的 bean id
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:p="http://www.springframework.org/schema/p"xmlns:c="http://www.springframework.org/schema/c"xmlns:util="http://www.springframework.org/schema/util"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/utilhttp://www.springframework.org/schema/util/spring-util-4.0.xsd"><bean id="cat" class="com.demo.autowired.Cat"/><bean id="dog" class="com.demo.autowired.Dog"/><!-- byName:會自動在容器上下文中查找,和自己對象set方法后面的值對應的bean id --><bean id="person" class="com.demo.autowired.Person" autowire="byName">
<!-- <property name="cat" ref="cat"/>-->
<!-- <property name="dog" ref="dog"/>--><property name="name" value="張三"/></bean>
</beans>
MyTest 類:
import com.demo.autowired.Person;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;public class Mytest {@Testpublic void test(){ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");Person person = context.getBean("person", Person.class);person.getCat().shout();person.getDog().shout();}
}
同理,ByType:會自動在容器上下文中查找和自己對象屬性類型相同的 bean
(Cat、Dog 的 id 都可以省略)
<bean class="com.demo.autowired.Cat"/>
<bean class="com.demo.autowired.Dog"/>
<!-- byType:會自動在容器上下文中查找,和自己對象屬性類型相同的bean -->
<bean id="person" class="com.demo.autowired.Person" autowire="byType"><property name="name" value="張三"/>
</bean>
總結:
byName 需要保證所有?bean 的 id 唯一,并且這個 bean 需要和自動注入的屬性的 set 方法值一致
byType 需要保證所有?bean 的 class 唯一,并且這個 bean 需要和自動注入的屬性的類型一致
注解實現自動裝配:
Person 類添加 @Autowired 注解(在屬性上使用或者在 Set 方法上使用)
beans.xml 文件:
導入 context 約束:xmlns:context="http://www.springframework.org/schema/context"
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
配置注解的支持:<context:annotation-config/>
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:p="http://www.springframework.org/schema/p"xmlns:c="http://www.springframework.org/schema/c"xmlns:context="http://www.springframework.org/schema/context"xmlns:util="http://www.springframework.org/schema/util"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/utilhttp://www.springframework.org/schema/util/spring-util-4.0.xsd"><!-- 開啟注解的支持 --><context:annotation-config/><bean id="cat" class="com.demo.autowired.Cat"/><bean id="dog" class="com.demo.autowired.Dog"/><bean id="person" class="com.demo.autowired.Person"><property name="name" value="張三"/></bean></beans>
如果顯示定義了 Autowired 的 required 屬性為 false,說明這個對象可以為 null,否則不允許為空
@Nullable 字段標記了這個注解,說明這個字段可以為 null
@Qualifier(value="xx") 可以指定唯一的 bean 對象注入(需和 @Autowired 搭配使用)
@Resource 和 @Autowired 的區別:
1.都是用來自動裝配的,都可以放在屬性字段上
2. @Autowired 通過 byType 方式實現,這個對象是必須存在的
3.?@Resource 默認通過 byName 方式實現,如果找不到,則通過 byType 方式實現
如果二者都找不到,就報錯