軟件開發(fā)的管理方法
當(dāng)今對(duì)于軟件系統(tǒng)的開發(fā),不僅僅需要掌握計(jì)算機(jī)開發(fā)語言的編程技巧,更重要的是掌握一個(gè)軟件工程在需求分析、系統(tǒng)分析及測(cè)試階段所需要的工作技巧,即軟件的開發(fā)方法。國外大的軟件公司和機(jī)構(gòu)一直在研究
軟件開發(fā)方法這個(gè)概念性的東西,而且也提出了很多實(shí)際的開發(fā)方法,比如:生命周期法、原型化方法、面向?qū)ο蠓椒ǖ。下面?jiǎn)單介紹幾種流行的
軟件開發(fā)方法,以供
軟件開發(fā)人員參考。
一、結(jié)構(gòu)化方法
結(jié)構(gòu)化開發(fā)方法是由E.Yourdon 和L.L.Constantine提出的,即所謂SASD方法,也是可稱為面向功能的
軟件開發(fā)方法或面向數(shù)據(jù)流的
軟件開發(fā)方法。SASD方法是20世紀(jì)80年代使用最廣泛的
軟件開發(fā)方法。它首先用結(jié)構(gòu)化分析(SA)對(duì)軟件進(jìn)行需求分析,然后用結(jié)構(gòu)設(shè)計(jì)(SD)方法進(jìn)行總體設(shè)計(jì),最后是結(jié)構(gòu)化編程(SP)。它給出了兩類典型的軟件結(jié)構(gòu)(變換型和事務(wù)型),使用
軟件開發(fā)的成功率大大提高。
Jackson方法是最典型的面向數(shù)據(jù)結(jié)構(gòu)的
軟件開發(fā)方法。Jackson方法把問題分解為可由三種基本結(jié)構(gòu)形式表示的各部分的層次結(jié)構(gòu)。三種基本的結(jié)構(gòu)形式就是順序、選擇和重復(fù)。三種數(shù)據(jù)結(jié)構(gòu)可以進(jìn)行組合,形成復(fù)雜的結(jié)構(gòu)體系。這一方法從目標(biāo)系統(tǒng)的輸入、輸出數(shù)據(jù)結(jié)構(gòu)入手,到數(shù)據(jù)框架結(jié)構(gòu),再補(bǔ)充其它細(xì)節(jié),就可以得到完整的程序結(jié)構(gòu)圖。這一方法對(duì)輸入、輸出數(shù)據(jù)結(jié)構(gòu)明確的中小型系統(tǒng)特別有效,如商業(yè)應(yīng)用中的文件表格處理。該方法也可以與其他方法結(jié)合,用于模塊的詳細(xì)設(shè)計(jì)。
三、面向問題的分析法
PAM(problem analysis method)方法是20世紀(jì)80年代由日立公司提出的一種
軟件開發(fā)方法。它的基本思想是考慮到輸入、輸出數(shù)據(jù)結(jié)構(gòu),指導(dǎo)系統(tǒng)的分解,在系統(tǒng)分析指導(dǎo)下逐步綜合。這一方面的具體步驟是:從輸入、輸出數(shù)據(jù)結(jié)構(gòu)導(dǎo)出基本處理框;分析這些處理框之間的先后關(guān)系;按先后關(guān)系逐步綜合處理框,直到畫出整個(gè)系統(tǒng)的PAD圖。這一方法本質(zhì)上是綜合的自底向上的方法,但在逐步綜合之前已進(jìn)行了有目的的分解,這個(gè)目的就是充分考慮系統(tǒng)的輸入、輸出數(shù)據(jù)結(jié)構(gòu)。PAM方法的另一個(gè)優(yōu)點(diǎn)是使用PAD圖。這是一種二維樹形結(jié)構(gòu)圖,是到目前為止最好的詳細(xì)設(shè)計(jì)的表示方法之一。但由于在輸入、輸出數(shù)據(jù)結(jié)構(gòu)與整個(gè)系統(tǒng)之間存在著鴻溝,這一方法仍只適用于中小型問題。
四、原型化方法
產(chǎn)生原型化方法的原因很多。主要是隨著我們系統(tǒng)開發(fā)經(jīng)驗(yàn)的增多,發(fā)現(xiàn)并非所有的需求都能夠預(yù)先定義,反復(fù)修改是不可避免的。當(dāng)然能夠采用原型化方法也是因?yàn)殚_發(fā)工具的快速發(fā)展,比如用VB、Delphi等工具,我們可以迅速地開發(fā)出一個(gè)可以讓用戶看得見、摸得著的系統(tǒng)框架,這樣,對(duì)于計(jì)算機(jī)不是很熟悉的用戶就可以根據(jù)這個(gè)樣板提出自己的需求。 開發(fā)原型化系統(tǒng)一般有以下幾個(gè)階段:
1.確定用戶需求
2.開發(fā)原始模型
3.征求用戶對(duì)初始原型的改進(jìn)意見
4.修改原型
原型化開發(fā)比較適合于用戶需求不清、業(yè)務(wù)理論不確定、需求經(jīng)常變化的情況。當(dāng)系統(tǒng)規(guī)模不是很大也不太復(fù)雜時(shí),采用該方法是比較好的。
五、面向?qū)ο蟮?a href="http://ahlulei.com" title="軟件定制開發(fā)公司" target="_blank" class="sitelink">軟件開發(fā)方法
當(dāng)前計(jì)算機(jī)業(yè)界最流行的幾個(gè)詞就是分布式、并行和面向?qū)ο筮@幾個(gè)術(shù)語,由此可以看到“面向?qū)ο蟆边@個(gè)概念在當(dāng)前計(jì)算機(jī)業(yè)界的地位,比如當(dāng)前流行的兩大面向?qū)ο蠹夹g(shù)DCOM和CORBA就是例子。當(dāng)前我們實(shí)際用到的還是面向?qū)ο蟮木幊陶Z言,比如C++。不可否認(rèn),面向?qū)ο蠹夹g(shù)是軟件技術(shù)的一次革命,在
軟件開發(fā)史上具有里程碑式的意義。
隨著OOP(面向?qū)ο缶幊蹋┫騉OD(面向?qū)ο笤O(shè)計(jì))和OOA(面向?qū)ο蠓治觯┑陌l(fā)展,最終形成面向?qū)ο蟮?a href="http://ahlulei.com" title="軟件定制開發(fā)公司" target="_blank" class="sitelink">軟件開發(fā)方法OMT(object modeling technique)。這是一種自底向上和自頂向下相結(jié)合的方法,而且它以對(duì)象建模為基礎(chǔ),不僅考慮了輸入、輸出數(shù)據(jù)結(jié)構(gòu),實(shí)際上也包含了所有對(duì)象的數(shù)據(jù)結(jié)構(gòu),所以O(shè)MT徹底實(shí)現(xiàn)了PAM沒有完全實(shí)現(xiàn)的目標(biāo)。不僅如此,OOP技術(shù)在需求分析上、可維護(hù)性和可靠性這三個(gè)
軟件開發(fā)的關(guān)鍵環(huán)節(jié)和質(zhì)量指標(biāo)上也有了實(shí)質(zhì)性的突破,基本解決了在這方面存在的嚴(yán)重問題。
綜上所述,面向?qū)ο箝_發(fā)采用了自底向上的歸納、自頂向下的分解的方法,它通過對(duì)對(duì)象模型的建立,能夠真正基于用戶的需求,而且系統(tǒng)的可維護(hù)性大大改善。當(dāng)前業(yè)界關(guān)于面向?qū)ο蠼5臉?biāo)準(zhǔn)是UML(Unified Modeling Language)。
六、可視化開發(fā)方法
其實(shí)可視化開發(fā)并不能單獨(dú)地作為一種開發(fā)方法,更加貼切地說它是一種輔助的工具,比如用過Sybase的S-Design的人都知道,用這個(gè)工具可以進(jìn)行顯示圖形化的數(shù)據(jù)庫模式的建立,并可以導(dǎo)出到不同的數(shù)據(jù)庫中去。當(dāng)然用過S-Design的人不一定很多,但用過VB、Delphi、C++、Builder等開發(fā)工具的人一定不少,實(shí)際上這部分人就是在使用可視化開發(fā)工具。
當(dāng)然,不可否認(rèn)的是,使用這些可視化開發(fā)工具也只是在編程這個(gè)環(huán)節(jié)上用了可視化,而不是在系統(tǒng)分析和系統(tǒng)設(shè)計(jì)這個(gè)層次上用了可視化。實(shí)際上,建立系統(tǒng)分析和系統(tǒng)設(shè)計(jì)的可視化工具是一個(gè)很好的賣點(diǎn),國外有很多工具開發(fā)商都在致力于這方面產(chǎn)品的設(shè)計(jì)。
可視化開發(fā)使我們的注意力集中在業(yè)務(wù)流程上,用戶界面可以通過可視化工具方便地構(gòu)成。通過操作界面元素,諸如菜單、按鈕、對(duì)話框、編輯框、單選框、復(fù)選框、列表框和滾動(dòng)條等,由可視化開發(fā)工具自動(dòng)生成應(yīng)用軟件。