您好,登錄后才能下訂單哦!
其思想是反轉(zhuǎn)資源獲取的方向. 傳統(tǒng)的資源查找方式要求組件向容器發(fā)起請求查找資源. 作為回應(yīng), 容器適時的返回資源. 而應(yīng)用了 IOC 之后, 則是容器主動地將資源推送給它所管理的組件, 組件所要做的僅是選擇一種合適的方式來接受資源. 這種行為也被稱為查找的被動形式
即組件以一些預(yù)先定義好的方式(例如: setter 方法)接受來自如容器的資源注入. 相對于 IOC 而言,這種表述更直接
<constructor-arg></constructor-arg>
<property></property>
abstract屬性為true的時候,IOC容器不會實例化對象,如果value屬性含有特殊字符,需要使用<![CDATA[]]>包裹起來
<property name="group">
<list>
<ref bean="developer"></ref>
<ref bean="developer"></ref>
</list>
</property>
<property name="adminEmails">
<props>
<prop key="administrator">administrator@example.org</prop>
<prop key="support">support@example.org</prop>
<prop key="development">development@example.org</prop>
</props>
</property>
<property name="someMap">
<map>
<entry key="an entry" value="just some string"/>
<entry key ="a ref" value-ref="myDataSource"/>
</map>
</property>
<property name="someSet">
<set>
<value>just some string</value>
<ref bean="myDataSource" />
</set>
</property>
Factory類本身不需要實例化,這個Factory類中提供了1個靜態(tài)方法來生成bean對象
public class StaticAddressFactory {
private static Map<String, Address> addressMap = new HashMap<String, Address>() ;
static {
addressMap.put("JINAN", new Address("JINAN", "SHILIHE"));
addressMap.put("QINGDAO", new Address("QINGDAO", "SIFANG"));
}
public static Address getAddress(String name){
return addressMap.get(name);
}
}
Factory類本身需要實例化
public class SigletonAddressFactory {
public Map<String, Address> getAddressMap() {
return addressMap;
}
public void setAddressMap(Map<String, Address> addressMap) {
this.addressMap = addressMap;
}
private Map<String, Address> addressMap = new HashMap<String, Address>() ;
public Address getAddress(String name){
return this.addressMap.get(name);
}
}
比工廠方法模式更常見,Factory Bean工廠類必須實現(xiàn)spring提供的FactoryBean的接口
重寫以下三個方法:
public class MyAddressFactory implements FactoryBean<Address> {
private String city;
private String street;
public String getCity() {
return city;
}
public void setCity(String city) {
this.city = city;
}
public String getStreet() {
return street;
}
public void setStreet(String street) {
this.street = street;
}
@Override
public Address getObject() throws Exception {
return new Address(this.city, this.street);
}
@Override
public Class<?> getObjectType() {
return Address.class;
}
@Override
public boolean isSingleton() {
return false;
}
}
通過FactoryBean方式,從IOC容器里面bean,通過FactoryBean的getObject返回指定的bean,property: MyAddressFactory的屬性設(shè)置
對于掃描到的組件, Spring 有默認的命名策略: 使用非限定類名, 第一個字母小寫. 也可以在注解中通過 value 屬性值標識組件的名稱
在組件類上使用了特定的注解之后, 還需要在 Spring 的配置文件中聲明 <context:component-scan> :
base-package 屬性指定一個需要掃描的基類包,Spring 容器將會掃描這個基類包里及其子包中的所有類.
當需要掃描多個包時, 可以使用逗號分隔.
如果僅希望掃描特定的類而非基包下的所有類,可使用 resource-pattern 屬性過濾特定的類
當bean增加注解@Scope("prototype"),那么就是獲得的多實例的bean
對于掃描到的組件, Spring 有默認的命名策略:
<!--在context中聲明需要檢測的bean目錄,同時會檢測目錄的子目錄-->
<context:component-scan base-package="com.annotation"></context:component-scan>
<!--
掃描base-package目錄子的某一個子目錄,可以利用resource-pattern
<context:component-scan base-package="com.annotation" resource-pattern="子目錄/*.class"></context:component-scan>
-->
單例模式
每次取出的bean對象都需要實例化
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。