Spring IOC裝配Bean過程解析
Spring的依賴注入
Spring主要支持兩種依賴注入方式,分別是屬性注入和構造函數注入。同時也支持工廠方法注入方式。
屬性注入
屬性注入的方式非常簡單,即指通過setXxx()方法注入Bean的屬性值或依賴對象。如下實例
編寫User類
public class User { private String username; private String address; public User() { } public User(String username, String address) { this.username = username; this.address = address; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } @Override public String toString() { return 'User{' +'username=’' + username + ’’’ +', address=’' + address + ’’’ +’}’; }}
編寫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' xmlns:p='http://www.springframework.org/schema/p' xsi:schemaLocation='http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd'> <bean class='com.rookie.bigdata.domain.User'> <property name='username' value='張三'></property> <property name='address' value='北京'></property> </bean></beans>
測試
ApplicationContext applicationContext=new ClassPathXmlApplicationContext('injection/bean.xml');
User user=(User)applicationContext.getBean('user');System.out.println(user);
構造函數注入
構造函數注入是屬性注入的另一種常用的注入方式。
xml配置方式如下
<bean class='com.rookie.bigdata.domain.User'> <constructor-arg name='username' value='李四'></constructor-arg> <constructor-arg name='address' value='上海'></constructor-arg></bean>
注入參數
XML中含有5個特殊符號,分別是&,<,>,”,‘,如果配置文件中的注入值包含這些特殊的字符,就需要進行特殊的處理。有兩種解決方法,其一:采用特殊標簽,將包含特殊字符的字符串封裝起來。其二:使用XML轉義序列表示這些特殊字符。
<bean class='com.rookie.bigdata.domain.User'> <property name='username' value='張三'></property> <!-- <property name='address' value='北京'></property>--> <property name='address'> <value><![CDATA[北京&通州]]></value> </property></bean>
特殊字符 轉義序列 特殊字符 轉義序列 < < “ " > > ’ ' & &
基于注解的配置
<context:component-scan base-package='com.rookie.bigdata.annotation'></context:component-scan>
component-scan 的base-package屬性指定一個需要掃描的基類包,Spring容器會掃描這個基類包里面的所有的屬性,并從類的注解信息中獲取Bean的定義信息。
如果想掃描特定的類,可以使用resource-pattern屬性過濾出特定的類。如:
<context:component-scan base-package='com.rookie.bigdata' resource-pattern='annotation/*.class'></context:component-scan>
即Spring僅會掃描基類包里annotation子包中的類。
通過使用resource-pattern發現,還是有很多時候并不滿足要求,此時可以通過過濾表達式。如下:
類別 示例 說明 annotation com.rookie.bigdata.XxxAnnotation 所有標注了XxxAnnotation的類,該類型采用目標類是否標注了某個注解進行過濾 assignable com.rookie.bigdata.XxxService 所有繼承或擴展XxxService的類,該類型采用目標類是否繼承或擴展了某個特定類進行過濾 aspectj com.rookie.bigdata.*Service+ 所有類名以Service結束的類及繼承或擴展它們的類,該類采用AspectJ表達式進行過濾 regex com.rookie.bigdata.annotation.* 所有com.rookie.bigdata.annotation類包下的類,該類型采用正則表達式根據目標類的類名進行過濾 custom com.rookie.bigdata.XxxTypeFilter 采用XxxTypeFile代碼方式實現過濾規則。該類必須實現org.springframework.core.type.TypeFilter接口
<context:component-scan/>有一個容易忽視的use-default-filters屬性,默認值為true;表示默認會對標注@Component、@Controller、@Service及Reposity的Bean進行掃描,<context:component-scan/>先根據<exclude-filter>列出需要排除的黑名單,再通過<include-filter>列出需要包含的白名單。
自動裝配Bean
Spring通過@Authwired注解實現Bean的依賴注入
如下:
@Repositorypublic class UserDao { public UserDao(){ System.out.println('實例化userDao'); }}
@Servicepublic class UserService { @Autowired private UserDao userDao;}
@Autowired默認按照類型(byType)匹配的方式在容器中查找匹配的Bean,當有且僅有一個匹配的Bean時,Spring將其注入@Autowired標注的變量中
@Autowired還有一個required屬性,默認情況下為true;表示必須找到匹配的Bean,否則會報NoSuchBeanDefinitionException異常。
@Autowired(required =true)private UserDao userDao;
@Qualifier注解
如果容器中有一個以上的匹配Bean時,可以通過@Qualifier注解限定Bean的名稱。如下:
@Repository@Qualifier(value = 'userDao')public class UserDao { public UserDao(){ System.out.println('實例化userDao'); }}
@Servicepublic class UserService { @Autowired(required =true) @Qualifier(value = 'userDao') private UserDao userDao;}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
相關文章: