首頁(yè) 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡(luò)課程 模擬考試 考友錄 實(shí)用文檔 繽紛校園 英語(yǔ)學(xué)習(xí)
2010考研 | 自學(xué)考試 | 成人高考 | 專 升 本 | 法律碩士 | MBA/MPA | 中 科 院
四六級(jí) | 商務(wù)英語(yǔ) | 公共英語(yǔ) | 職稱日語(yǔ) | 職稱英語(yǔ) | 博思 | 口譯筆譯 | GRE GMAT | 日語(yǔ) | 托福
雅思 | 專四專八 | 新概念 | 自考英語(yǔ) | 零起點(diǎn)英、、、、韓語(yǔ) | 在職申碩英語(yǔ)
在職攻碩英語(yǔ) | 成人英語(yǔ)三級(jí)
等級(jí)考試 | 水平考試 | 微軟認(rèn)證 | 思科認(rèn)證 | Oracle認(rèn)證 | Linux認(rèn)證
公務(wù)員 | 報(bào)關(guān)員 | 報(bào)檢員 | 外銷員 | 司法考試 | 導(dǎo)游考試 | 教師資格 | 國(guó)際商務(wù)師 | 跟單員
單證員 | 物流師 | 價(jià)格鑒證師 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 人力資源管理師 | 管理咨詢師
期貨從業(yè)資格 | 社會(huì)工作者
會(huì)計(jì)職稱 | 注會(huì)CPA | 經(jīng)濟(jì)師 | 統(tǒng)計(jì)師 | 注冊(cè)稅務(wù)師 | 評(píng)估師 | 精算師 | 高會(huì) | ACCA | 審計(jì)師
法律顧問 | 會(huì)計(jì)證
一級(jí)建造師 | 二級(jí)建造師 | 造價(jià)師 | 監(jiān)理師 | 安全師 | 咨詢師 | 結(jié)構(gòu)師 | 建筑師 | 安全評(píng)價(jià)師
房地產(chǎn)估價(jià)師 | 土地估價(jià)師 | 設(shè)備監(jiān)理師 | 巖土工程師 | 質(zhì)量資格 | 房地產(chǎn)經(jīng)紀(jì)人 | 造價(jià)員
投資項(xiàng)目管理 | 土地代理人 | 環(huán)保師 | 環(huán)境影響評(píng)價(jià) | 物業(yè)管理師 | 城市規(guī)劃師 | 公路監(jiān)理師
公路造價(jià)工程師 | 招標(biāo)師
執(zhí)業(yè)護(hù)士 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 衛(wèi)生資格
您現(xiàn)在的位置: 考試吧(Exam8.com) > 軟件水平考試 > 系統(tǒng)分析師 > 正文

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

在軟件開發(fā)中,我們對(duì)于軟件架構(gòu)經(jīng)?吹綐O端,要么不重視軟件架構(gòu),要么過分重視以至于她成了“天條”。我甚至遇到了這樣的事情,某公司強(qiáng)制推行某基于Struts的架構(gòu)設(shè)計(jì),然而到了項(xiàng)目組它卻處處遭到抵制,特別是分部基本上拋棄了這個(gè)架構(gòu)設(shè)計(jì)。那么,這個(gè)原因在哪里呢?為什么一個(gè)成本高昂的架構(gòu)設(shè)計(jì)沒有被接納呢?

  實(shí)際上有時(shí)候一個(gè)良好的設(shè)計(jì)也未必會(huì)被接納,特別是沒有Java開發(fā)實(shí)際經(jīng)驗(yàn)甚至缺乏軟件開發(fā)經(jīng)驗(yàn)的項(xiàng)目經(jīng)理試圖控制技術(shù)的時(shí)候更加如此。我們拋開這個(gè)可能的影響來(lái)看待這個(gè)問題。

  我們發(fā)現(xiàn),很多的設(shè)計(jì)人員在做軟件架構(gòu)設(shè)計(jì)的時(shí)候忽略了幾個(gè)重要的問題

  1.軟件的架構(gòu)在大的方向上是固定的

  這種固定依據(jù)某些基本固定的軟件模式(包括設(shè)計(jì)模式、編碼模式或者某些特定的約定)來(lái)強(qiáng)化和固定。這使得軟件開發(fā)在某種程度上具有某些可以明顯看得到的風(fēng)格,這個(gè)風(fēng)格被整個(gè)的項(xiàng)目貫穿和堅(jiān)持,這樣當(dāng)我們進(jìn)入通?膳碌木S護(hù)或者調(diào)整的時(shí)候,我們不會(huì)害怕我們?cè)诤芏喾N不同的實(shí)現(xiàn)中常常迷失了方向。

  2.軟件的架構(gòu)在具體的應(yīng)用中可以適度的可控靈活

  毫無(wú)疑問,軟件設(shè)計(jì)開發(fā)不可能沒有例外,在某種程度上保留一些適度的靈活時(shí)必要的。一方面,它符合軟件開發(fā)的實(shí)際;一方面,適度的可控靈活體現(xiàn)了一種對(duì)實(shí)現(xiàn)者的尊重和信任。然而,如何實(shí)現(xiàn)可控的靈活呢?通常,我認(rèn)為可以考慮有限種類的設(shè)計(jì)選擇并通過有色彩的圖形來(lái)表明這種可選擇性。但即便如此,設(shè)計(jì)者很重要的要考慮這些不同選擇之間的關(guān)系,以及這些選擇和整體設(shè)計(jì)的兼容性,這個(gè)時(shí)候,面向接口的設(shè)計(jì)和適度的“粘合”設(shè)計(jì)是必要的。 mda.com  

  3.架構(gòu)設(shè)計(jì)的支撐

  架構(gòu)設(shè)計(jì)通常會(huì)涉及到一些支撐設(shè)計(jì),這些設(shè)計(jì)和實(shí)現(xiàn)水準(zhǔn)直接的體現(xiàn)了系統(tǒng)的最有價(jià)值的部分,更細(xì)的劃分我們應(yīng)該可以看到性能和結(jié)構(gòu)相關(guān)的部分,以及必要的基礎(chǔ)類。通常,作為設(shè)計(jì)人員,我們應(yīng)該能夠設(shè)計(jì)并實(shí)現(xiàn)系統(tǒng)的性能、結(jié)構(gòu)、擴(kuò)展、粘合等部分的工作,這部分的工作通常不應(yīng)該離開設(shè)計(jì)人員的控制和把握,這些代碼的書寫或者至少積極的關(guān)注是設(shè)計(jì)人員必要的素質(zhì).我們不應(yīng)該讓更多的看到我們無(wú)法寫出代碼來(lái)(我也反對(duì)沒有分工什么都做的設(shè)計(jì)人員!),實(shí)際上,這是軟件最困難也是最有樂趣的地方。特別是在測(cè)試結(jié)果中發(fā)現(xiàn)這些設(shè)計(jì)實(shí)現(xiàn)帶來(lái)的性能的極大提高的時(shí)候是非常有成就感的事情。至于基礎(chǔ)類,應(yīng)該是盡可能的減少依賴和耦合的。架構(gòu)設(shè)計(jì)的支撐要盡可能的對(duì)客戶程序員隱藏不必要的中間細(xì)節(jié),對(duì)基礎(chǔ)類要盡量簡(jiǎn)單、穩(wěn)定并真正需要。

  通常,新興的技術(shù)會(huì)用在架構(gòu)設(shè)計(jì)的支撐設(shè)計(jì)里面并被封裝以隱藏具體的實(shí)現(xiàn),而通盤應(yīng)用新興技術(shù)的風(fēng)險(xiǎn)是巨大的,并且對(duì)人員的獲得也是問題。有些技術(shù)是可以提供替代技術(shù)的,一些新興的技術(shù)實(shí)現(xiàn)也是可以參考的(但未必采用她的實(shí)現(xiàn))。要記住軟件開發(fā)是需要速度、質(zhì)量、可維護(hù)而不是技術(shù)表演,這個(gè)度應(yīng)該由分析設(shè)計(jì)人員負(fù)責(zé)任的來(lái)把握。

轉(zhuǎn)帖于:軟件水平考試_考試吧
文章搜索
軟件架構(gòu):可控的靈活性網(wǎng)友評(píng)論網(wǎng)友評(píng)論
版權(quán)聲明 --------------------------------------------------------------------------------------
    如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請(qǐng)與我們聯(lián)系,我們將會(huì)及時(shí)處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請(qǐng)注明出處。
 gaoxiaoliang