談談程序開發中,關於“零配置”和“有配置”的看法

本人是做Java開發的,在程序開發中會經常使用到OpenSource開源框架,這些框架大多都靈活、簡單、易用、方便。而且開源框架一般會提供一些基本的配置,如我們常用的框架就有Hibernate要配置對象實體到數據庫的映射;Spring要配置bean的管理及其對象、屬性的注入;Struts要配置Action對象和返回的資源路徑;MyBatis要配置CRUD(增刪改查)的相關SQL語句。這些配置你不能省略,必須得有,沒有程序也不會自動添加。我們也是極可能的簡化這些配置,不管怎麼樣簡化但這些配置是不能省略,雖然這些框架給我們開發程序都提供了很大方面上的便利。

但有時候你是否有糾結這麼樣的一個問題:到底是用XML配置?還是用Annotation註解配置?或是用XML和Annotation混合配置?

首先看看兩種配置的優缺點比較

XML它是無可代替的超文本標記語言,可讀性、傳輸性好,它還具有一下優點:
1、可讀性、傳輸性好:XML可擴展標記語言,最大的優勢在於開發者能夠爲軟件量身定製適用的標記,使代碼可讀性大大提升。
2、靈活性、易用性、擴展性、移植性好:利用XML配置能使軟件更具擴展性。如Spring將class間的依賴配置在XML中,最大限度地提升應用的可擴展性。同樣,如果是基於接口注入方式,可以隨便切換接口實現類進行注入即可。
3、驗證機制:具有成熟的驗證機制確保程序正確性。利用Schema或DTD可以對XML的正確性進行驗證,避免了非法的配置導致應用程序出錯。
4、修改配置而無需變動現有程序、無需重新編譯。

雖然XML有如此多的好處,但它也不是萬能的,XML也有自身的缺點:
1、開發友好性支持:需要解析工具或類庫的支持。如果你的XML配置需要用到XML的提示或是解析編譯,需要用到Schema或DTD進行驗證。
2、性能影響:解析XML勢必會影響應用程序性能,佔用系統資源。至少你會用到一些解析XML的技術去解析節點元素內容。
3、維護性高:配置文件過多導致管理變得困難。
4、編譯期無法對其配置項的正確性進行驗證,或要查錯只能在運行期。如Spring Bean配置了一個錯誤的類路徑class。
5、IDE 無法驗證配置項的正確性無能爲力。如Spring注入一個錯誤的對象或屬性。
6、查錯變得困難。往往配置的一個手誤導致莫名其妙的錯誤。
7、開發人員不得不同時維護代碼和配置文件,開發效率變得低下。
8、配置項與代碼間存在潛規則,改變了任何一方都有可能影響另外一方。

讓我們來看看Annotation的優點
1、保存在class文件中,降低維護成本。
2、無需工具支持,無需解析。
3、編譯期即可驗證正確性,查錯變得容易,雖然有部分錯誤需要在運行期間才能看到。
4、配置簡單、簡約,提升開發效率。

同樣Annotation也不是萬能的,它也有很多缺點
1、若要對配置項進行修改,不得不修改Java文件,重新編譯打包應用。
2、配置項編碼在Java文件中,可擴展性差、移植性性低。

那到底用什麼樣的配置呢,在這裏我談談我個人的看法:
1、在開發期間我們用Annotation註解,這樣在一定程度上不僅可以省去對XML配置文件的維護,而且大大的提高了開發效率,縮短了開發週期。
2、開發後期,項目功能完成,我們可以將Annotation配置轉換爲XML配置,禁用Annotation即可。這樣做的理由是如果項目上線,我們需要修改相關代碼的配置,直接改XML、properties配置文件即可。這樣就不需要開發人員找到相應的代碼修改源代碼、重新編譯打包發佈。而xml的配置是可以直接修改的,不需要重新編譯,只需重啓下你的服務器即可。

如果這樣是不是即利用到框架給我們提供的Annotation註解,也利用到了XML配置。充分的發揮了開源框架給我們提供的技術應用。

3、混合模式,Annotation和XML相互運用。需要動態配置、後期經常性修改的就用XML配置,如果是不怎麼修改的就用Annotation。或許這種混合模式更適合我們,你覺得呢?O(∩_∩)O~

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章