Spring利用依賴注入可以獲得簡單而有效的測試能力。Spring beans,依賴關係,以及服務所需要的bean都將在配置文件中予以描述,配置文件一般採用XML格式。然而XML配置文件冗長而不易使用,在你進行一個使用了大量bean的大項目中它將變得難以閱讀和控制。
在這篇文章中我將給你展示12種的有關Spring XML配置文件的最佳技巧。請注意另外一些因素,例如域模型的設計,會影響到XML配置,但是這篇文章更關注於XML配置的可讀性和可操控性。
1.避免使用自動裝配
Spring可以通過bean類的自省來實現自動裝配依賴,這樣的話你就不必明確地描述bean的屬性或者構造函數的參數。根據屬性名稱活匹配類型,bean屬性可以自動進行裝配。而構造函數可以根據匹配類型自動裝配。你甚至可以設置自動裝配進行自動偵測,這樣Spring替你就會選擇一個合適的機制。請看下面的例子:
Spring可以通過bean類的自省來實現自動裝配依賴,這樣的話你就不必明確地描述bean的屬性或者構造函數的參數。根據屬性名稱活匹配類型,bean屬性可以自動進行裝配。而構造函數可以根據匹配類型自動裝配。你甚至可以設置自動裝配進行自動偵測,這樣Spring替你就會選擇一個合適的機制。請看下面的例子:
class="com.lizjason.spring.OrderService"autowire="byName"/> |
2.使用命名規範
和Java編碼的理念一樣,在項目中始終用清晰的,描述性的,一致的命名規範對開發人員理解XML配置非常有用。拿bean ID舉例來說,你可以遵循Java類中屬性的命名規範。比如說,OrderServiceDAO的bean ID應該是orderServiceDAO。對於大項目來說,在bean ID前加包名來作爲前綴。
3.使用簡化格式
簡化格式有利於減少冗餘,因爲它把屬性值和引用作爲屬性,而不是子元素。看下面的例子:
class="com.lizjason.spring.OrderService">lizjason |
class="com.lizjason.spring.OrderService">value="lizjason"/> 簡化格式在1.2版本時已經可用了,但請注意不存在這種簡化格式不僅可以較少你的代碼輸入量,而且可以使XML配置更加的清晰。當你的配置文件中存在大量的bean定義時,它可以顯著地提高可讀性。4.儘量使用type而不是index去解決構造函數參數的匹配問題當構造函數中有多個同類型的參數時,Spring只允許你使用從0開始的index或者value標籤來解決這個問題。請看下面的例子:class="com.lizjason.spring.BillingService">
最好用type屬性取代上面的做法: class="com.lizjason.spring.BillingService">value="lizjason"/>
用index可以稍微減少冗餘,但是它更容易出錯且不如type屬性可讀性高。你應該僅在構造函數中有參數衝突時使用index。
5.如可能,儘量複用bean定義
Spring提供了一種類似於繼承的機制來降低配置信息的重複並使XML配置更加的簡單。一個子bean可以從它的父bean繼承配置信息,本質上這個父bean就像它的子bean的一個模板。這是一個在大型項目中必須使用的特性。所有你要做的就是把父bean的abstract屬性置爲true,並在子bean中加以引用。例如:
class="com.lizjason.spring.AbstractService">value="lizjason"/>parent="abstractService"class="com.lizjason.spring.ShippingService"> |
6.儘量使用ApplicationContext裝配bean,而不是用import像Ant腳本中imports一樣,Spring的import 元素對於模塊化bean的裝配非常有用,例如:class="com.lizjason.spring.OrderService"/>
然而,比起在XML中用imports預裝配這些bean,利用ApplicationContext來配置它們將更加靈活,也可以使XML配置更加的易於管理。你可以像下面這樣傳遞一個bean定義數組到ApplicationContext的構造函數中:
String[] serviceResources ={"orderServices.xml","billingServices.xml","shippingServices.xml"};
ApplicationContext orderServiceContext = newClassPathXmlApplicationContext(serviceResources); |
8.在開發階段使用依賴檢查你可以爲bean的dependency-check屬性設置一個值來取代默認的none,比如說simple,objects或者all,這樣的話容器將替你做依賴有效性的檢查。當一個bean的所有屬性(或者某些屬性目錄)都被明確設置,或利用自動裝配時將會非常有用。class="com.lizjason.spring.OrderService"dependency-check="objects">value="lizjason"/> 在這個例子中,容器將確保這些屬性不是privitives或者保證collections是爲orderService bean設置的。爲所有的bean設置默認的依賴檢查是可能的,但這個特性由於有些bean的屬性不需要設置而很少使用。
9.爲每個配置文件加一個描述註釋
在XML配置文件中最好使用有描述性的id和name,而不是成堆的註釋。另外,加一個文件描述頭將會非常有用,這個描述可以概括文件中定義的bean。另一個選擇,你可以在description元素中加入描述信息。例如:
This file defines billing servicerelated beans and it depends onbaseServices.xml,which providesservice bean templates......
用description元素的一個好處就是工具可以很容易的把描述信息從這個元素中提取出來。
10.和team members溝通變更
當你修改java源碼後,要確保更改了配置文件中的相應部分並把這個情況告知你的team members。XML配置文件也是代碼,它們是程序的重要組成部分,但它們很難閱讀和維護。大多數時間裏,你需要同時看XML配置文件和java代碼才能知道是怎麼回事。
11.setter注入和構造函數注入,優先使用前者
Spring提供了三種注入方式:構造函數注入,setter注入和方法注入。一般我們使用前兩種。
class="com.lizjason.spring.OrderService">class="com.lizjason.spring.BillingService">ref="billingDAO"> |
=============================================
http://www.cnblogs.com/lzhdim/archive/2008/12/25/1362481.html