《代碼大全》第5章 軟件構(gòu)建中的設(shè)計(jì) 讀書筆記
管理軟件的復(fù)雜度
設(shè)計(jì)層次
1. 軟件系統(tǒng)
2. 子系統(tǒng)或包
常用子系統(tǒng)劃分形式:
- 業(yè)務(wù)規(guī)則:法規(guī)、政策、規(guī)定等
- 用戶界面
- 數(shù)據(jù)庫訪問
- 系統(tǒng)依賴性:對操作系統(tǒng)和硬件的依賴因素
- 軟件功能實(shí)現(xiàn)
3. 類
4. 子程序
5. 子程序內(nèi)部設(shè)計(jì)
信息隱藏
- 隱藏復(fù)雜度:大部分時(shí)候不用去應(yīng)付復(fù)雜度
- 隱藏變化源:發(fā)生變化時(shí),影響被限制在局部
保持松散耦合
按耦合的緊密程度排列
- 簡單數(shù)據(jù)參數(shù)耦合:傳遞簡單數(shù)據(jù)類型作為參數(shù)
- 簡單對象耦合:一個(gè)模塊實(shí)例化一個(gè)對象(?)
- 對象參數(shù)耦合:傳遞對象作為參數(shù)
- 語義耦合:一個(gè)模塊使用了另一個(gè)模塊內(nèi)部工作細(xì)節(jié)的語義知識
常用設(shè)計(jì)模式
- 提供現(xiàn)成的抽象來減少復(fù)雜度
- 把常見解決方案的細(xì)節(jié)進(jìn)行制度化來減少出錯(cuò)
- 通過提供多種設(shè)計(jì)方案而帶來啟發(fā)性價(jià)值
- 把設(shè)計(jì)對話提升到更高層次來簡化交流
自上而下和自下而上的設(shè)計(jì)方法
- 自上而下:從高度抽象,向下逐漸分解
- 自下而上:實(shí)現(xiàn)最基本的職能后向上擴(kuò)展