软件工程——瀑布模型、快速原型模型、增量模型、螺旋模型
目錄
一、瀑布模型
1.1什么是瀑布模型
1.2特點
1.3優(yōu)缺點
1.4客戶需求
二、快速原型模型
2.1什么是快速原型模型
2.2優(yōu)缺點
2.3快速原型模型的思想產生、原理及運用方式
2.4類型
2.5開發(fā)步驟
三、增量模型
3.1什么是增量模型
3.2特點
3.3優(yōu)缺點
3.4作用
四、螺旋模型
4.1什么是螺旋模型
4.2特點
4.3優(yōu)缺點
4.4限制條件
一、瀑布模型
1.1什么是瀑布模型
1970年溫斯頓.羅伊斯提出了著名的“瀑布模型”,直到80年代早期,它一直是唯一被廣泛采用的軟件開發(fā)模型
瀑布模型將軟件生命周期劃分為制定計劃、需求分析、軟件設計、程序編寫、軟件測試和運行維護等六個基本活動,并且規(guī)定了它們自上而下、相互銜接的固定次序,如同瀑布流水,逐級下落
瀑布模型是最早出現(xiàn)的軟件開發(fā)模型,在軟件工程中占有重要的地位,它提供了軟件開發(fā)的基本框架。其過程是從上一項活動接收該項活動的工作對象作為輸入,利用這一輸入實施該項活動應完成的內容給出該項活動的工作成果,并作為輸出傳給下一項活動
從本質來講,它是一個軟件開發(fā)架構,開發(fā)過程是通過一系列階段順序展開的,從系統(tǒng)需求分析開始直到產品發(fā)布和維護,每個階段都會產生循環(huán)反饋,因此,如果有信息未被覆蓋或者發(fā)現(xiàn)了問題,那么最好 “返回”上一個階段并進行適當?shù)男薷?#xff0c;開發(fā)進程從一個階段“流動”到下一個階段,這也是瀑布開發(fā)名稱的由來
對于經常變化的項目而言,瀑布模型毫無價值
1.2特點
1、階段間具有順序性和依賴性
該階段具有兩重含義
2、推遲實現(xiàn)的觀點
對于規(guī)模較大的軟件項目來說,往往編碼開始的越早,最終完成開發(fā)所需時間越長。因為前面階段的工作沒做或做的不扎實,過早地考慮進行程序實現(xiàn),往往導致大量返工,有時甚至發(fā)生無法彌補的問題
瀑布模型在編碼之前設置了系統(tǒng)分析與系統(tǒng)設計的各個階段,分析與設計階段的基本任務規(guī)定,在這兩個階段主要考慮目標系統(tǒng)的邏輯模型,不涉及軟件的物理實現(xiàn)
清楚的區(qū)分邏輯設計與物理設計,盡可能推遲程序的物理實現(xiàn),是按照瀑布模型開發(fā)軟件的一條重要的指導思想
3、質量保證的觀點
為了保證所開發(fā)的軟件的質量,在瀑布模型的每一個階段都應堅持兩個重要做法
傳統(tǒng)的瀑布模型過于理想化,實際的瀑布模型是帶"反饋環(huán)"的。如圖所示(圖中實線箭頭表示開發(fā)過程,虛線箭頭表示維護過程),當在后面階段發(fā)現(xiàn)前面階段的錯誤時,需要沿圖中左側的反饋線返回前面的階段,修正前面階段的產品后再回來繼續(xù)完成后面階段的任務
瀑布模型是文檔驅動的模型,遵守這個約束可使軟件維護變得比較容易一些,從而顯著降低軟件預算
1.3優(yōu)缺點
優(yōu)點:
- 為項目提供了按階段劃分的檢查點
- 當前一階段完成后,您只需要去關注后續(xù)階段
- 可在迭代模型中應用瀑布模型
缺點:
- 不適合需求模糊或需求經常變動的系統(tǒng)
- 由于開銷的逐步升級問題,它不希望存在早期階段的反饋
- 在一個系統(tǒng)完成以前,它無法預測一個新系統(tǒng)引入一個機構的影響
- 在用戶可能需要較長等待時間來獲得一個可供使用的系統(tǒng),也許會給用戶的信任程度帶來影響和打擊
- 最終產品往往反映用戶的初始需求而不是最終需求
1.4客戶需求
對項目而言,是否使用這一模型主要取決于是否能理解客戶的需求以及在項目的進程中這些需求的變化程度;對于經常變化的項目而言,瀑布模型毫無價值,可以考慮其他的架構來進行項目管理,比如螺旋模型
瀑布模型強調文檔的作用,并要求每個階段都要仔細驗證。但是,這種模型的線性過程太理想化,已不再適合現(xiàn)代的軟件開發(fā)模式,幾乎被業(yè)界拋棄,其主要問題在于:
按照瀑布模型的階段劃分,軟件測試可以分為單元測試,集成測試,系統(tǒng)測試
?
二、快速原型模型
2.1什么是快速原型模型
快速原型是快速建立起來的可以在計算機上運行的程序,它所能完成的功能往往是最終產品能完成的功能的一個子集
快速原型模型是增量模型的另一種形式,在開發(fā)真實系統(tǒng)之前,迅速建造一個可以運行的軟件原型 ,以便理解和澄清問題,在該原型的基礎上,逐漸完成整個系統(tǒng)的開發(fā)工作
它允許在需求分析階段對軟件的需求進行初步而非完全的分析和定義,快速設計開發(fā)出軟件系統(tǒng)的原型,該原型向用戶展示待開發(fā)軟件的全部或部分功能和性能;用戶對該原型進行測試評定,給出具體改進意見以豐富細化軟件需求;開發(fā)人員據(jù)此對軟件進行修改完善,直至用戶滿意認可之后,進行軟件的完整實現(xiàn)及測試、維護
2.2優(yōu)缺點
優(yōu)點
- 克服瀑布模型的缺點,減少由于軟件需求不明確帶來的開發(fā)風險
- 適合預先不能確切定義需求的軟件系統(tǒng)的開發(fā)
缺點
- 所選用的開發(fā)技術和工具不一定符合主流的發(fā)展;快速建立起來的系統(tǒng)結構加上連續(xù)的修改可能會導致產品質量低下
- 使用前提是要有一個展示性的產品原型,一定程度上可能會限制開發(fā)人員的創(chuàng)新
2.3快速原型模型的思想產生、原理及運用方式
1、思想產生
在需求分析階段得到完全、一致、準確、合理的需求說明十分困難
獲得一組基本需求說明后,就快速地使其“實現(xiàn)”,通過原型反饋,加深對系統(tǒng)的理解滿足用戶基本要求,使用戶在試用后對需求說明進行補充和精確化,從而獲得合理完整、現(xiàn)實可行的需求說明
再把快速原型思想用到軟件開發(fā)的其他階段,向軟件開發(fā)的全過程擴展
先用相對少的成本,較短的周期開發(fā)一個簡單的、但可以運行的系統(tǒng)原型向用戶演示或讓用戶試用,以便及早澄清并檢驗一些主要設計策略,在此基礎上再開發(fā)實際的軟件系統(tǒng)
2、原理
利用原型輔助軟件開發(fā)
經過簡單快速分析快速實現(xiàn)一個原型,用戶與開發(fā)者在試用原型過程中加強通信與反饋,通過反復評價和改進原型,減少誤解,彌補漏洞,最終提高軟件質量
3、運用方式
由于運用原型的目的和方式不同,在使用原型時也采取不同的策略
- 拋棄策略:將原型用于開發(fā)過程的某個階段,促使該階段的開發(fā)結果更加完整、準確、一致、可靠,該階段結束后,原型隨之作廢。探索型和實驗型就是采用此策略的
- 附加策略:將原型用于開發(fā)的全過程,原型由最基本的核心開始,逐步增加新的功能和新的需求,反復修改反復擴充,最后發(fā)展為用戶滿意的最終系統(tǒng),演化型快速原型就是采用此策略
采用何種形式、何種策略運用快速原型主要取決于軟件項目的特點、可供支持的原型開發(fā)工具和技術等,根據(jù)實際情況的特點決定
2.4類型
在軟件開發(fā)中,原型是軟件的一個早期可運行的版本,它反映最終系統(tǒng)的部分重要特性
探索型
這種原型目的是要弄清對目標系統(tǒng)的要求,確定所希望的特性,并探討多種方案的可行性
實驗型
這種原型用于大規(guī)模開發(fā)和實現(xiàn)之前,考核方案是否合適,規(guī)格說明是否可靠
進化型
這種原型的目的不在于改進規(guī)格說明,而是將系統(tǒng)建造得易于變化,在改進原型的過程中,逐步將原型進化成最終系統(tǒng)
2.5開發(fā)步驟
1、快速分析
在分析人員與用戶密切配合下,迅速確定系統(tǒng)的基本需求,根據(jù)原型需要體現(xiàn)的特征描述基本需求以滿足開發(fā)原型的需要
2、構造原型
在快速分析的基礎上,根據(jù)基本需求說明盡快實現(xiàn)一個可行的系統(tǒng)
要求具有強有力的軟件工具的支持,并忽略最終系統(tǒng)在某些細節(jié)上的要求,主要考慮原型系統(tǒng)能夠充分反映所要評價的特性
3、運行原型
發(fā)現(xiàn)問題,消除誤解,開發(fā)者與用戶充分協(xié)調
4、評價原型
在運行的基礎上,考核評價原型的特性,分析運行效果是否滿足用戶的愿望,糾正過去交互中的誤解與分析中的錯誤,增添新的要求,并滿足因環(huán)境變化或用戶的新想法引起的系統(tǒng)要求變動,提出全面的修改意見
5、修改
根據(jù)評價原型的活動結果進行修改
若原型未滿足需求說明的要求,說明對需求說明存在不一致的理解或實現(xiàn)方案不夠合理,根據(jù)明確的要求迅速修改原型
快速原型模型不帶反饋環(huán),軟件產品的開發(fā)基本上是線性順序進行的
快速原型的本質是"快速"。開發(fā)人員應盡可能地建造出原型系統(tǒng),以加速軟件開發(fā)過程,節(jié)約軟件開發(fā)成本
原型的用途是獲知用戶的真正需求,一旦需求確定了,原型將被拋棄
?
三、增量模型
3.1什么是增量模型
增量模型也稱漸增模型。使用增量模型開發(fā)軟件時,把軟件產品作為一系列的增量構件來設計、編碼、集成和測試。每個構件由多個相互作用的模塊構成,并且能夠完成特定的功能
使用增量模型時,第一個增量構件往往實現(xiàn)軟件的基本需求,提供最核心的功能
把軟件產品分解成增量構件時,唯一必須遵守的約束條件是,當把新構件集成到現(xiàn)有構件中時,所形成的產品必須是可測試的
瀑布模型或快速原型模型目標是一次就把一個滿足所有需求的產品提交給用戶
增量模型把整個軟件產品分解成許多個增量構件,分批地逐步向用戶提交產品
3.2特點
把瀑布模型的順序特征與快速原型法的迭代特征相結合
將軟件看作一系列相互聯(lián)系的增量,在開發(fā)過程的各次迭代中,每次完成其中的一個增量
風險更大的增量模型
確定用戶需求后就著手擬定第一個構件的規(guī)格說明文檔,完成后規(guī)格說明組轉向第二個構件的規(guī)格說明文檔,同時設計組開始涉及第一個構件
使用該方法將不同的構件并行構建,可能加快工程進度,但將冒構建無法集成到一起的風險
3.3優(yōu)缺點
優(yōu)點
缺點
3.4作用
1、開發(fā)初期的需求定義只是用來確定軟件的基本結構,使得開發(fā)初期用戶只需要對軟件需求進行大概的描述;而對于需求的細節(jié)性描述,則可以延遲到增量構件開發(fā)時進行,以增量構件為單位逐個地進行需求補充。這種方式能夠有效適應用戶需求的變更
2、軟件系統(tǒng)可以按照增量構件的功能安排開發(fā)的優(yōu)先順序,并逐個實現(xiàn)和交付使用。不僅有利于用戶盡早用上系統(tǒng),能夠更好地適應新的軟件環(huán)境,而且在以增量方式使用系統(tǒng)的過程中,還能獲得對軟件系統(tǒng)后續(xù)構件的需求經驗
3、軟件系統(tǒng)是逐漸擴展的,因此開發(fā)者可以通過對諸多構件的開發(fā),逐步積累開發(fā)經驗。實際上,增量式開發(fā)還有利于技術復用,前面構件中設計的算法、采用的技術策略、編寫的源碼等,都可以應用到后面將要創(chuàng)建的增量構件中去
4、增量式開發(fā)有利于從總體上降低軟件項目的技術風險。個別的構件或許不能使用,但一般不會影響到整個系統(tǒng)的正常工作
5、實際上,在采用增量模型時,具有最高優(yōu)先權的核心增量構件將會被最先交付,而隨著后續(xù)構件不斷被集成進系統(tǒng),這個核心構件將會受到最多次數(shù)的測試。這意味著軟件系統(tǒng)最重要的心臟部分將具有最高的可靠性,這將使得整個軟件系統(tǒng)更具健壯性
?
四、螺旋模型
4.1什么是螺旋模型
螺旋模型是一種演化軟件開發(fā)過程模型,它兼顧了快速原型的迭代特征以及瀑布模型的系統(tǒng)化與嚴格監(jiān)控。螺旋模型最大的特點在于引入了其他模型不具備的風險分析,使軟件在無法排除重大風險時有機會停止,以減小損失。同時,在每個迭代階段構建原型是螺旋模型用以減小風險的途徑
螺旋模型是快速原型模型以進化的開發(fā)方式為中心,在每個項目階段使用瀑布模型法。該模型的每一個周期都包括需求定義、風險分析、工程實現(xiàn)和評審4個階段,由這4個階段進行迭代。軟件開發(fā)過程每迭代一次,軟件開發(fā)又前進一個層次。用螺旋模型的軟件過程如下
簡化的螺旋模型
完整的數(shù)據(jù)模型
?
圖中帶箭頭的點劃線的長度代表當前累計的開發(fā)費用,螺旋線的角度值代表開發(fā)進度,螺旋線的每個周期對應于一個開發(fā)階段
圖中的四個象限代表了以下活動
4.2特點
螺旋模型在“瀑布模型”的每一個開發(fā)階段前引入一個非常嚴格的風險識別、風險分析和風險控制,它把軟件項目分解成一個個小項目。每個小項目都標識一個或多個主要風險,直到所有的主要風險因素都被確定
螺旋模型強調風險分析,使得開發(fā)人員和用戶對每個演化層出現(xiàn)的風險有所了解,繼而做出應有的反應,因此特別適用于龐大、復雜并具有高風險的系統(tǒng)
4.3優(yōu)缺點
優(yōu)點
缺點
4.4限制條件
一個階段首先是確定該階段的目標,完成這些目標的選擇方案及其約束條件,然后從風險角度分析方案的開發(fā)策略,努力排除各種潛在的風險,有時需要通過建造原型來完成。如果某些風險不能排除,該方案立即終止,否則啟動下一個開發(fā)步驟。最后,評價該階段的結果,并設計下一個階段
總結
以上是生活随笔為你收集整理的软件工程——瀑布模型、快速原型模型、增量模型、螺旋模型的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 收藏这些芯片原厂的代码仓库
- 下一篇: Presto入门介绍