潛魚在淵

          Concentrating on Architectures.

          posts - 77, comments - 309, trackbacks - 0, articles - 0
            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

          軟件架構(gòu):決策與選擇

          Posted on 2008-09-18 22:54 非魚 閱讀(2343) 評論(4)  編輯  收藏 所屬分類: 面向?qū)ο笤O(shè)計(jì)
          架構(gòu)師最重要的工作是思考。思考導(dǎo)致決策,或者選擇。

          為決策而思考

          架構(gòu)師思考的出發(fā)點(diǎn)是成就受益人的利益,目的就是為了最終做出決策。在開始的時(shí)候,往往會(huì)有一些明顯的途徑,也會(huì)有一些隱含的途徑。架構(gòu)師要根據(jù)所掌握的信息,結(jié)合自身的知識、經(jīng)驗(yàn),盡可能找出所有的途徑,思考哪條途徑是最合適的。在這個(gè)過程中,有一些途徑會(huì)很快被排除。排除一條途徑的依據(jù),首先是軟件的價(jià)值,其次是軟件的假設(shè)和前提。良好的實(shí)踐是記錄這些思考過程中被排除的途徑,特別是對于經(jīng)驗(yàn)不是特別豐富的架構(gòu)師來說,這非常重要。

          需要特別提出的是,不要因?yàn)椴痪稠?xiàng)技術(shù)而排除可行的途徑。因?yàn)橐话闱闆r下,技術(shù)對軟件價(jià)值的影響是次要的。比如,當(dāng)你在JSF和struts之間搖擺的時(shí)候,把這個(gè)問題提出來討論,是更好的做法。

          決策需要依據(jù)

          決策是合理的(Reasonable)選擇。架構(gòu)師需要考慮各種選擇的優(yōu)缺點(diǎn),再根據(jù)實(shí)際情況,找到支持決策的依據(jù)。因?yàn)閭€(gè)人及項(xiàng)目等多方面的原因,這些依據(jù)也可能是不充分的。但這不要緊,最重要的是,決策要有依據(jù),這就夠了。在思考和討論的過程中,對于反面的意見(不支持決策的依據(jù)),也要充分考慮和記錄,因?yàn)椴恢朗裁磿r(shí)候,這些因素會(huì)因環(huán)境、認(rèn)識的變化而由假成真,如果沒有相關(guān)的記錄,你會(huì)為此而失去一次寶貴的成長機(jī)會(huì)。:)

          有時(shí)候也需要選擇

          人的智力是有限的,眼界也是有限的。有時(shí)候你會(huì)發(fā)現(xiàn)幾條路徑很難說哪個(gè)更優(yōu)一點(diǎn)。這時(shí)候你面臨的就是選擇,像擲骰子一樣。這是架構(gòu)設(shè)計(jì)中風(fēng)險(xiǎn)最大的地方。墨菲定律說:“凡事只要有可能出錯(cuò),那就一定會(huì)出錯(cuò)。”(Anything that can go wrong will go wrong.)把這個(gè)選擇記錄下來,只要可能,就要來重新評價(jià)。

          如果沒有選擇的余地

          任何時(shí)候,如果你感覺只有一種選擇(或者你毫無理由的排除了其他選擇),這可能說明:

          1. 你的知識還不夠,過早進(jìn)入架構(gòu)設(shè)計(jì)的領(lǐng)域,對你不是一件好事;或者

          2. 你憑借感覺做決策,實(shí)在不適合做架構(gòu)師這樣的工作。




          by 非魚。Technorati 標(biāo)簽: , ,

          評論

          # re: 軟件架構(gòu):決策與選擇  回復(fù)  更多評論   

          2008-09-19 08:22 by Jack.Wang
          說的很好。
          決策方面都點(diǎn)到了,但沒展開,希望看到點(diǎn)決策方法技巧和您個(gè)人經(jīng)驗(yàn)的分享。
          相信筆者思維和經(jīng)驗(yàn)都很強(qiáng)。

          # re: 軟件架構(gòu):決策與選擇  回復(fù)  更多評論   

          2008-09-19 11:21 by duan
          說的很好,很喜歡這種思想的傳授。

          # re: 軟件架構(gòu):決策與選擇  回復(fù)  更多評論   

          2008-09-19 11:45 by leekiang
          知識不夠,用忽悠來彌補(bǔ)。
          最害怕那些連線程、事務(wù)、并發(fā),IO等都搞不清楚的架構(gòu)師了,偏偏這樣的人最會(huì)忽悠。

          # re: 軟件架構(gòu):決策與選擇  回復(fù)  更多評論   

          2008-09-26 13:26 by xu_zh_h
          說的真切
          主站蜘蛛池模板: 昭平县| 阳东县| 高雄县| 澜沧| 凤阳县| 石泉县| 扶风县| 车致| 石景山区| 大港区| 运城市| 石泉县| 化州市| 大安市| 萨嘎县| 明水县| 喀什市| 灌云县| 迁安市| 德令哈市| 祁连县| 台安县| 贵阳市| 阳高县| 宣恩县| 丰原市| 卢龙县| 姜堰市| 江西省| 泌阳县| 永州市| 九龙县| 恭城| 岳普湖县| 墨江| 道孚县| 辉县市| 五原县| 石景山区| 夹江县| 平湖市|