Spring中XML配置文件的十二個最佳方法(下)

引用:http://developer.51cto.com/art/200906/129820.htm

 

本文介紹Spring中XML配置文件的十二個最佳方法中的後六個,包括爲每個配置文件添加首部註釋,Setter注入優於構造函數注入等。

7. 使用id作爲bean標識符

可以指定一個id或名稱來作爲bean標識符。雖然使用id不能提高可讀性,但是它可以利用XML分析程序來對bean引用進行驗證。如果由於XML IDREF的約束而不能使用某個id,那麼可以使用名稱來作爲bean的標識符。XML IDREF的約束是:id必須以字母(或者XML規範中定義的標點符號)開頭,後面是字母、數字、連字符、下劃線、冒號或句點。實際上,很少會遇到XML IDREF約束問題。

 

8. 在開發階段使用依賴性檢查(dependency-check)

可以在bean定義中爲dependency-check屬性設置一個非默認值,比如simple、objects或all,以便容器進行依賴性檢查。當需要顯式或通過自動綁定設置bean的全部屬性(或某類屬性)時,依賴性檢查便顯得很有用。

 

<bean id="orderService" 

        class="com.lizjason.spring.OrderService" 

        dependency-check="objects"> 

        <property name="companyName" 

            value="lizjason"/> 

        <constructor-arg ref="orderDAO"/> 

    </bean>  

在這個例子中,容器確保爲orderService bean設置的屬性不是primitives或collections。也可以爲所有的bean設置默認依賴性檢查,但是我們很少這樣做,因爲有些bean屬性根本就不必設置。

 

9. 爲每個配置文件添加首部註釋

最好使用描述性的id和名稱來取代XML配置文件中的內置註釋。此外,添加一個配置文件首部也很有用,它可以概述文件中所定義的bean。可以選擇將描述添加到description標籤中。例如:

 

<beans> 

        <description> 

            This file defines billing service  

            related beans and it depends on  

            baseServices.xml,which provides  

            service bean templates...  

        </description> 

        ...  

    </beans> 

使用description標籤的一個好處是可以輕鬆地利用工具從標籤中選獲取描述內容。

 

10. 對於更改,團隊成員要積極交流

在重構Java代碼時,需要隨時更新配置文件並通知團隊成員。XML配置文件也是代碼,它們是應用程序的至關重要的部分,但是它們難於閱讀和維護。大部分情況下,需要同時閱讀XML配置文件和運行中的Java代碼。

 

11. Setter注入優於構造函數注入

Spring提供了3種類型的依賴注入:構造函數注入(constructor injection)、setter注入(setter injection)和方法注入(method injection)。我們一般只用前兩種。

 

<bean id="orderService" 

        class="com.lizjason.spring.OrderService"> 

        <constructor-arg ref="orderDAO"/> 

    </bean> 

    <bean id="billingService" 

        class="com.lizjason.spring.BillingService"> 

        <property name="billingDAO" 

            ref="billingDAO"> 

    </bean>  

在這個例子中,orderService類使用的是構造函數注入,而BillingService類使用的是setter注入。構造函數注入可以確保 bean不會在一個非法狀態下被創建,但是setter注入更加靈活且更易於管理,尤其是在類包含許多屬性並且其中一些可選的情況下。

 

12. 不要濫用依賴注入

最 後一點,Spring ApplicationContext可以爲您創建Java對象,但並不是所有的Java對象都應通過依賴注入來創建。例如,全局對象不應該通過 ApplicationContext來創建。Spring是一個很棒的框架,但是,就可讀性和易管理性而言,如果定義了大量bean,基於XML的配置就可能成爲問題。過度使用依賴注入會使XML配置變得複雜且臃腫。要知道,藉助於功能強大的IDE(如Eclipse和IntelliJ),Java代碼比XML文件更加易讀、易維護、易管理。

 

結束語

XML是通用的Spring配置方式。但如果定義了大量bean,基於XML的配置就會變得冗長而不實用。Spring提供了豐富的配置選項,恰當地利用其中的選項可以使XML配置更清晰,但是,有些選項(如autowiring)往往會降低配置文件的可讀性和可維護性。遵循本文中所描述的最佳實踐,將有助於您創建出清晰易讀的XML配置文件。

發佈了108 篇原創文章 · 獲贊 22 · 訪問量 9萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章