軟件架構(gòu):可控的靈活性

字號:

在軟件開發(fā)中,我們對于軟件架構(gòu)經(jīng)??吹綐O端,要么不重視軟件架構(gòu),要么過分重視以至于她成了“天條”。我甚至遇到了這樣的事情,某公司強制推行某基于Struts的架構(gòu)設(shè)計,然而到了項目組它卻處處遭到抵制,特別是分部基本上拋棄了這個架構(gòu)設(shè)計。那么,這個原因在哪里呢?為什么一個成本高昂的架構(gòu)設(shè)計沒有被接納呢?
    實際上有時候一個良好的設(shè)計也未必會被接納,特別是沒有Java開發(fā)實際經(jīng)驗甚至缺乏軟件開發(fā)經(jīng)驗的項目經(jīng)理試圖控制技術(shù)的時候更加如此。我們拋開這個可能的影響來看待這個問題。
    我們發(fā)現(xiàn),很多的設(shè)計人員在做軟件架構(gòu)設(shè)計的時候忽略了幾個重要的問題:
    1.軟件的架構(gòu)在大的方向上是固定的
    這種固定依據(jù)某些基本固定的軟件模式(包括設(shè)計模式、編碼模式或者某些特定的約定)來強化和固定。這使得軟件開發(fā)在某種程度上具有某些可以明顯看得到的風(fēng)格,這個風(fēng)格被整個的項目貫穿和堅持,這樣當(dāng)我們進入通??膳碌木S護或者調(diào)整的時候,我們不會害怕我們在很多種不同的實現(xiàn)中常常迷失了方向。
    2.軟件的架構(gòu)在具體的應(yīng)用中可以適度的可控靈活
    毫無疑問,軟件設(shè)計開發(fā)不可能沒有例外,在某種程度上保留一些適度的靈活時必要的。一方面,它符合軟件開發(fā)的實際;一方面,適度的可控靈活體現(xiàn)了一種對實現(xiàn)者的尊重和信任。然而,如何實現(xiàn)可控的靈活呢?通常,我認為可以考慮有限種類的設(shè)計選擇并通過有色彩的圖形來表明這種可選擇性。但即便如此,設(shè)計者很重要的要考慮這些不同選擇之間的關(guān)系,以及這些選擇和整體設(shè)計的兼容性,這個時候,面向接口的設(shè)計和適度的“粘合”設(shè)計是必要的。 來源:www.examda.com
    3.架構(gòu)設(shè)計的支撐
    架構(gòu)設(shè)計通常會涉及到一些支撐設(shè)計,這些設(shè)計和實現(xiàn)水準(zhǔn)直接的體現(xiàn)了系統(tǒng)的最有價值的部分,更細的劃分我們應(yīng)該可以看到性能和結(jié)構(gòu)相關(guān)的部分,以及必要的基礎(chǔ)類。通常,作為設(shè)計人員,我們應(yīng)該能夠設(shè)計并實現(xiàn)系統(tǒng)的性能、結(jié)構(gòu)、擴展、粘合等部分的工作,這部分的工作通常不應(yīng)該離開設(shè)計人員的控制和把握,這些代碼的書寫或者至少積極的關(guān)注是設(shè)計人員必要的素質(zhì).我們不應(yīng)該讓更多的看到我們無法寫出代碼來(我也反對沒有分工什么都做的設(shè)計人員?。?,實際上,這是軟件最困難也是最有樂趣的地方。特別是在測試結(jié)果中發(fā)現(xiàn)這些設(shè)計實現(xiàn)帶來的性能的極大提高的時候是非常有成就感的事情。至于基礎(chǔ)類,應(yīng)該是盡可能的減少依賴和耦合的。架構(gòu)設(shè)計的支撐要盡可能的對客戶程序員隱藏不必要的中間細節(jié),對基礎(chǔ)類要盡量簡單、穩(wěn)定并真正需要。
    通常,新興的技術(shù)會用在架構(gòu)設(shè)計的支撐設(shè)計里面并被封裝以隱藏具體的實現(xiàn),而通盤應(yīng)用新興技術(shù)的風(fēng)險是巨大的,并且對人員的獲得也是問題。有些技術(shù)是可以提供替代技術(shù)的,一些新興的技術(shù)實現(xiàn)也是可以參考的(但未必采用她的實現(xiàn))。要記住軟件開發(fā)是需要速度、質(zhì)量、可維護而不是技術(shù)表演,這個度應(yīng)該由分析設(shè)計人員負責(zé)任的來把握。