軟件工程知識點匯總_第1頁
軟件工程知識點匯總_第2頁
軟件工程知識點匯總_第3頁
軟件工程知識點匯總_第4頁
軟件工程知識點匯總_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、精選文檔軟件工程知識點匯總1 軟件工程、軟件工程方法學(xué):三要素1.1 軟件工程:應(yīng)用系統(tǒng)化的、規(guī)范化的、可度量的方法來開發(fā)、運行和維護軟件,即將工程應(yīng)用到軟件;對的各種方法的研究1.2 軟件工程是一門研究用工程化方法構(gòu)建和維護有效的實用的和高質(zhì)量的軟件的學(xué)科1.3 軟件工程三要素是:方法、工具、過程軟件工程的方法:是指完成軟件開發(fā)各項任務(wù)的技術(shù)方法軟件工具:是指為軟件工程方法的運用提供自動半自動的軟件支撐環(huán)境軟件工程過程:是指將軟件工程方法和工具綜合起來以達到合理、及時地進行計算機軟件開發(fā)這一目的2 軟件工程的原則包括:模塊化原則、信息隱蔽原則、抽象化原則、模塊獨立原則(內(nèi)聚、耦合)、依賴倒轉(zhuǎn)

2、原則、開閉原則等2.1 模塊化原則:指解決一個復(fù)雜問題時自頂向下逐層把軟件系統(tǒng)劃分為若干模塊的過程。模塊是程序中相對獨立的成分,一個獨立的編程單位,應(yīng)有良好的編程接口,模塊的大小要適中,模塊過大會使模塊內(nèi)部的復(fù)雜性增加不利于模塊的理解和修改,模塊過小會導(dǎo)致整個系統(tǒng)表示過于復(fù)雜,不利于控制系統(tǒng)的復(fù)雜性。2.2 信息隱蔽原則:采用封裝技術(shù),將程序模塊的實現(xiàn)細節(jié)隱藏起來,使模塊接口盡量簡單。2.3 抽象化原則:抽取事物最基本的特性和行為,忽略非本質(zhì)細節(jié),采用分層次抽象,自頂向下,逐層細化的辦法控制軟件開發(fā)過程的復(fù)雜性。2.4 模塊獨立原則:是指每個模塊只完成系統(tǒng)要求的獨立子功能,并且與其他模塊的聯(lián)系

3、最少且接口簡單。要求在一個物理模塊內(nèi)集中邏輯上相互關(guān)聯(lián)的計算機資源,保證模塊間由松散的偶合關(guān)系,模塊內(nèi)部有較強的內(nèi)聚性,這有助于控制系統(tǒng)的復(fù)雜性。(即:高內(nèi)聚低耦合)2.5 依賴倒轉(zhuǎn)原則:抽象不應(yīng)該依賴于細節(jié),細節(jié)應(yīng)該依賴于抽象。2.6 開閉原則:軟件實體應(yīng)該是可擴展的,但是不可以修改。即對于擴展是開放的,對于更改是封閉的。3 軟件開發(fā)模型:瀑布模型;快速原型;噴泉模型;各種模型的工作原理、階段、每階段任務(wù)、特點、示意圖;軟件開發(fā)模型(也稱為軟件過程模型):是從軟件項目需求定義開始直至軟件經(jīng)使用后廢棄為止,跨越整個生命周期的系統(tǒng)開發(fā)、運行和維護所實施的全部過程、活動和任務(wù)的結(jié)構(gòu)框架3.1 瀑布

4、模型(又稱線性模型):3.1.1 工作原理:規(guī)定了它們自上而下、相互銜接的固定次序,如同瀑布流水,逐級下落。前一階段的工作成果是后一階段工作開始的基礎(chǔ).所以,每個階段都必須交出合格的文檔,必須對前階段的工作進行評審,前一階段的工作完成后才可以開始后一階段的工作3.1.2 階段:計劃時期:問題定義、可行性研究開發(fā)時期:需求分析、設(shè)計、編碼、測試運行時期:運行和維護3.1.3 各階段任務(wù):1.需求分析和定義在軟件項目進行過程中,需求分析是從軟件定義到軟件開發(fā)的關(guān)鍵步驟,是今后軟件,開發(fā)的基本依據(jù),同時也是用戶對軟件產(chǎn)品進行驗收的基本依據(jù)。需求分析和定義是以用戶需求為基本依據(jù),從功能、性能、數(shù)據(jù)、操

5、作等多個方面,對軟件系統(tǒng)給出完整、準(zhǔn)確、具體的描述,用于確定軟件規(guī)格。2.軟件設(shè)計根據(jù)系統(tǒng)需求的定義,確定系統(tǒng)的結(jié)構(gòu),進行系統(tǒng)的概要設(shè)計和各部分的功能與結(jié)構(gòu)的詳細設(shè)計。3.編碼與單元測試在這一階段,根據(jù)軟件設(shè)計文檔完成了程序模塊或程序單元的編碼。通過程序單元測試,驗證其是否滿足設(shè)計規(guī)范。4.集成和系統(tǒng)測試程序模塊或程序單元被組裝集成起來成為一個軟件系統(tǒng),然后進行系統(tǒng)測試。測試完成后即交付用戶使用。5.運行和維護通常這是軟件生命周期中最長的一個階段。如果在運行期發(fā)現(xiàn)了軟件的錯誤,就要修改軟件,可能會重復(fù)上述某個或多個階段的活動。3.1.4 特點: 順序性、依賴性:下一階段依賴上一階段的完成。 推

6、遲實現(xiàn):階段任務(wù)結(jié)束形成文檔,并審核后方能進行設(shè)計任務(wù),將程序的實現(xiàn)推遲進行。 質(zhì)量保證:文檔完整、文檔評審,避免錯誤積累與放大效應(yīng)。3.1.5 示意圖:3.2 快速原型3.2.1 工作原理:快速原型是利用原型輔助軟件開發(fā)的一種新思想。經(jīng)過簡單快速分析,快速實現(xiàn)一個原型,用戶與開發(fā)者在試用原型過程中加強通信與反饋,通過反復(fù)評價和改進原型,減少誤解,彌補漏洞,適應(yīng)變化,最終提高軟件質(zhì)量。廢棄型:也稱快速建立需求規(guī)格原型法:先構(gòu)造一個功能簡單而質(zhì)量要求不高的模型系統(tǒng),針對這個模型系統(tǒng)反復(fù)的進行分析修改,從而形成較好的設(shè)計思想,據(jù)此設(shè)計出更加完整、準(zhǔn)確、一致可靠的最終系統(tǒng),系統(tǒng)構(gòu)造完成后,原來的模型

7、就被廢棄追加型:也稱快速建立漸進原型法。它采用循序漸進的開發(fā)方式,對系統(tǒng)模型作連續(xù)精化,即先構(gòu)造一個功能簡單而且質(zhì)量要求不高的模型系統(tǒng),最為最終系統(tǒng)的核心,將系統(tǒng)需要具備的性能逐步添加上去,通過不斷地擴充修改,逐步追加新的要求,直至所有性能全部滿足,此時原型模型也就是最終的產(chǎn)品。3.2.2 階段及任務(wù)原型快速分析:是指在分析者和用戶的緊密配合下,快速確定軟件系統(tǒng)的基本要求,根據(jù)原型所要體現(xiàn)的特性(總體結(jié)構(gòu)、處理功能、模擬性能、界面形式等),描述基本需求規(guī)格說明,以滿足開發(fā)圓形的需要。原型構(gòu)造:在快速原型分析的基礎(chǔ)上,根據(jù)基本需求規(guī)格說明,忽略細節(jié)只考慮主要特性快速構(gòu)造一個可運行的系統(tǒng)。原型運行

8、與評價:是軟件開發(fā)人員與用戶頻繁通信、發(fā)現(xiàn)問題、消除誤解的用藥階段,目的是驗證原型的正確程度,進而開發(fā)新的并修改原有的需求。原型修改:根據(jù)評價原型的活動結(jié)果進行修改。若原型未滿足需求說明的要求,說明對需求說明存在不一致的理解或?qū)崿F(xiàn)方案不夠合理,則根據(jù)明確的要求迅速修改原型。3.2.3 特點1增強了軟件開發(fā)人員和用戶對系統(tǒng)需求的理解,便于將用戶模糊的功能需求明確化2為用戶提供了一種強有力的學(xué)習(xí)手段3易于確定系統(tǒng)的性能,是理解和確定軟件需求規(guī)格說明的良好工具4按照快速建立漸進原型法建立的原型即為最終的產(chǎn)品利用快速原型化技術(shù)可以為軟件開發(fā)提供一種完整、靈活、近似動態(tài)的需求規(guī)格說明方法。3.2.4 示

9、意圖3.3 噴泉模型3.3.1 工作原理:噴泉模型是一種以用戶需求為動力,以對象為驅(qū)動的模型,主要用于描述面向?qū)ο蟮能浖_發(fā)過程。該模型認為軟件開發(fā)過程自下而上周期的各階段是相互重疊和多次反復(fù)的,各個開發(fā)階段沒有特定的次序要求,并且可以交互進行,可以在某個開發(fā)階段中隨時補充其他任何開發(fā)階段中的遺漏。3.3.2 階段3.3.3 每階段任務(wù)3.3.4 特點:噴泉模型體現(xiàn)了軟件創(chuàng)建所固有的迭代和無間隙的特征。迭代指系統(tǒng)中某個部分常常重復(fù)工作多次,無間隙指活動之間沒有明顯的間隙,如在分析和設(shè)計之間沒有明顯的界限。3.3.5 示意圖。4 軟件生命周期:階段、各階段功能、所涉及的內(nèi)容(圖、工具和文檔)4.

10、1 軟件生命周期:是指一個計算機軟件從功能確定、設(shè)計到開發(fā)成功投入使用,并在使用中不斷地修改、增補和完善,知道被新的需求所替代而停止該軟件的使用全過程。4.2 四個工作階段:初始階段:建立業(yè)務(wù)模型,定義最終產(chǎn)品視圖,并且確定項目的范圍。精化階段:設(shè)計并確定系統(tǒng)的體系結(jié)構(gòu),制定項目計劃,確定資源需求。構(gòu)建階段:開發(fā)出所有構(gòu)件和應(yīng)用程序,把它們集成為客戶需要的產(chǎn)品,并且詳盡地測試所有功能。移交階段:把開發(fā)出的產(chǎn)品提交給用戶使用4.3 各階段功能:1問題定義可行性研究可性研究的任務(wù)是以最小的代價在盡可能短的時間內(nèi)確定問題是否值得解決、是否能夠解決。階段性成果項目可行性報告2需求分析階段需求分析的主要

11、任務(wù)就是要通過軟件開發(fā)人員與用戶的交流和討論,準(zhǔn)確地獲取用戶對系統(tǒng)的具體要求。階段性成果需求規(guī)格說明書、數(shù)據(jù)字典、數(shù)據(jù)流圖(DFD)3概要設(shè)計階段劃分出組成系統(tǒng)的物理元素,設(shè)計軟件的結(jié)構(gòu),即確定模塊及模塊間的關(guān)系,根據(jù)需求分析階段得到的邏輯模型來設(shè)計系統(tǒng)的物理模型階段性成果概要設(shè)計說明書4詳細設(shè)計階段設(shè)計每個模塊的算法,確定每一模塊使用的數(shù)據(jù)結(jié)構(gòu),確定模塊接口的細節(jié),為每一個模塊設(shè)計一個測試用例,編寫詳細設(shè)計說明書軟件詳細設(shè)計文檔5編碼和單元測試6系統(tǒng)測試7軟件維護階段4.4 各階段所涉及的內(nèi)容(文檔、工具、圖)5 結(jié)構(gòu)化方法: 生命周期中各階段任務(wù).獲取用戶需求、畫數(shù)據(jù)流圖、數(shù)據(jù)字典6 可行

12、性分析、需求分析、設(shè)計(概要設(shè)計+詳細設(shè)計)、測試、維護7 面向?qū)ο蠓椒ǎ汉诵母拍?、模?.1 面向?qū)ο笾械幕靖拍睿簩ο螅捍砹艘粋€現(xiàn)實的或虛構(gòu)的實體類:對具有相同數(shù)據(jù)和相同操作的一組相似對象的定義繼承:子類自動的共享父類中定義的數(shù)據(jù)和方法的機制多態(tài)性:一個名字具有多種語義封裝:將屬性和操作包裝成一個單元,使得對狀態(tài)的訪問和修改只能通過封裝提供的接口進行消息:對象間在交互中所傳送的通訊信息關(guān)聯(lián):對象之間所存在的聯(lián)系7.2 模型對象模型:即尋找問題域中的對象,從對象中抽象出類的定義,識別對象的內(nèi)部特征,定義屬性,識別對象的外部關(guān)系,識別主題。動態(tài)模型:即建立交互圖、狀態(tài)圖和活動圖,進一步定義用

13、例。功能模型:即用例分析,以用例對用戶需求進行規(guī)范化描述;為了更好地理解問題,人們常采用建立建立問題模型的方法。模型就是為了理解事物而對事物作出的一種抽象,是對事物的一種無歧義的書面描述。通常,模型由一組圖示符號和組織這些符號的規(guī)則組成。模型是一種思考工具,可以把知識規(guī)范地表示出來。對于那些因過分復(fù)雜而不能直接理解的系統(tǒng),特別需要建立模型,建模的目的主要是為了減少復(fù)雜性。一旦建立起模型之后,就要經(jīng)受用戶和各個領(lǐng)域?qū)<业膰栏駥彶?。模型常常會?jīng)過多次必要的修改。用OO方法開發(fā)軟件,通常需要建立3種形式的模型:對象模型-描述系統(tǒng)數(shù)據(jù)結(jié)構(gòu);動態(tài)模型-描述系統(tǒng)控制結(jié)構(gòu);功能模型-描述系統(tǒng)功能;這三種模型

14、各自從不同的側(cè)面反映軟件系統(tǒng)的內(nèi)容,相互影響、相互制約,有機地結(jié)合在一起,全面地表達對目標(biāo)系統(tǒng)的需求。對象模型表示靜態(tài)的、結(jié)構(gòu)化的系統(tǒng)的“數(shù)據(jù)”性質(zhì)。描述了系統(tǒng)的靜態(tài)結(jié)構(gòu)。面向?qū)ο蠓椒◤娬{(diào)圍繞對象而不是功能來構(gòu)造系統(tǒng)。對象模型為建立動態(tài)模型和功能模型,提供了實質(zhì)性的框架。1997年11月,國際對象管理組織OMG批準(zhǔn)把UML1。1作為基于面向?qū)ο蠹夹g(shù)的標(biāo)準(zhǔn)建模語言。通常,使用UML的類圖來建立對象模型。在UML中術(shù)語“類”的實際含義是,“一個類及屬于該類的對象”-狀態(tài)模型表示瞬時的、行為化的系統(tǒng)的“控制”性質(zhì),它規(guī)定了對象模型中的對象的合法變化序列。一旦建立起對象模型之后,就需要考察對象的動態(tài)行

15、為。所有對象都具有自己的生命周期。狀態(tài),是對對象屬性值的一種抽象。各對象之間相互觸發(fā)就形成了一系列的狀態(tài)變化。一個觸發(fā)行為稱作一個事件。對象對事件 的響應(yīng),取決于接受該觸發(fā)的對象當(dāng)時所處的狀態(tài),響應(yīng)包括改變自己的狀態(tài)或者又形成一個新的觸發(fā)行為。狀態(tài)有持續(xù)性,它占用一段時間間隔。狀態(tài)與事件密不可分,一個事件隔開兩個狀態(tài),一個狀態(tài)隔開兩個事件。事件表示時刻,狀態(tài)表示時間間隔。UML中用狀態(tài)圖來描繪對象的狀態(tài)、觸發(fā)狀態(tài)轉(zhuǎn)換的事件及對象的行為。每個類的動態(tài)行為用一張狀態(tài)圖來描繪,各個類的狀態(tài)圖通過共享事件合并起來,從而構(gòu)成系統(tǒng)的動態(tài)模型。動態(tài)模型是基于事件共享而互相關(guān)聯(lián)的一組狀態(tài)圖的集合。-功能模型表

16、示變化的系統(tǒng)的“功能”性質(zhì),它指明了系統(tǒng)應(yīng)該“做什么”,因此更直接地反映了用戶對目標(biāo)系統(tǒng)的需求。通常,功能模型由一組數(shù)據(jù)流圖組成。在OO方法中,數(shù)據(jù)流圖遠不如在結(jié)構(gòu)化方法中那樣重要。但建立功能模型有助于開發(fā)人員更深入地理解問題域,改進和完善自己的設(shè)計。UML中提供的用例圖也是進行需求分析和建立功能模型的強有力工具。UML中把用例圖建立起來的系統(tǒng)模型稱為用例模型。使用用例模型代替?zhèn)鹘y(tǒng)的功能說明,往往能夠更好地獲取用戶需求,它所回答的問題是“系統(tǒng)應(yīng)該為每個(或每類)用戶做什么”。8 面向?qū)ο蠓椒?、UML:獲取用戶需求、畫用例圖、對象模型、UML中的關(guān)系1.面向?qū)ο蟮姆椒ǎ?)分析:包括問題描述、構(gòu)

17、建對象模型、構(gòu)建動態(tài)模型、構(gòu)建功能模型。最后得到的分析文檔包括問題需求的陳述、對象模型、動態(tài)模型和功能模型。(2)系統(tǒng)設(shè)計:結(jié)合問題域的知識和目標(biāo)系統(tǒng)的體系結(jié)構(gòu),將目標(biāo)系統(tǒng)分解為子系統(tǒng),標(biāo)識由問題所規(guī)定的并發(fā)性,設(shè)計適當(dāng)?shù)目刂茩C制組織子系統(tǒng)協(xié)調(diào)工作,然后選擇數(shù)據(jù)管理的基本策略,考慮對邊界條件的處理。最后得到的系統(tǒng)設(shè)計文檔包括基本的系統(tǒng)體系結(jié)構(gòu)和高層次的決策策略。(3)對象設(shè)計:以分析模型為基礎(chǔ),首先定義類,設(shè)計類屬性及操作,為每個操作選擇合適的數(shù)據(jù)結(jié)構(gòu)并定義算法,調(diào)整類結(jié)構(gòu)以強化繼承性;然后創(chuàng)建對象,設(shè)計消息以補充對象關(guān)聯(lián);通過關(guān)聯(lián)發(fā)現(xiàn)新的對象或交互條件時,修改類組織以優(yōu)化對數(shù)據(jù)的訪問,改善設(shè)

18、計結(jié)構(gòu)。最后得到的對象設(shè)計文檔包括細化的對象模型、細化的動態(tài)模型和細化的功能模型。(4)實現(xiàn):將設(shè)計轉(zhuǎn)換為特定編程語言代碼并在相應(yīng)環(huán)境運行,同時保持可追蹤性、靈活性和可擴展性。2.UML:統(tǒng)一建模語言(UML)是一個通用的可視化建模語言,用于對軟件進行描述、可視化處理、構(gòu)造和建立軟件系統(tǒng)產(chǎn)品的文檔 。UML描述了一個系統(tǒng)的靜態(tài)結(jié)構(gòu)和動態(tài)行為3.獲取用戶需求(1)與用戶進行充分溝通,了解用戶對軟件的需求;(2)識別對象集合及對象間的關(guān)系;(3)定義類(包括屬性和操作)并建立類間的層次關(guān)系;(4)建立模型來表示對象之間的關(guān)系及行為特性。4.用例圖:用例模型描述外部執(zhí)行者所理解的系統(tǒng)功能。用例模型用

19、于需求分析階段,描述待開發(fā)系統(tǒng)的功能要求,幫助軟件設(shè)計人員理解系統(tǒng)要做的工作,同時用例模型還可以為其他模型建立、結(jié)構(gòu)設(shè)計、實現(xiàn)及測試工作等提供依據(jù)。一個用例模型是由若干用例圖組成的,進行用例建模的過程主要包括尋找執(zhí)行者、尋找用例、描述用例、確定執(zhí)行者和用例之間的關(guān)系等工作,其中尋找執(zhí)行者和用例是用例建模的關(guān)鍵。5.對象模型:對象模型表示靜態(tài)的、結(jié)構(gòu)化的系統(tǒng)的“數(shù)據(jù)”性質(zhì)。描述了系統(tǒng)的靜態(tài)結(jié)構(gòu)。面向?qū)ο蠓椒◤娬{(diào)圍繞對象而不是功能來構(gòu)造系統(tǒng)。對象模型為建立動態(tài)模型和功能模型,提供了實質(zhì)性的框架。通常,使用UML的類圖來建立對象模型。在UML中術(shù)語“類”的實際含義是,“一個類及屬于該類的對象”6.關(guān)

20、系:依賴關(guān)聯(lián)泛化實現(xiàn)9 測試:黑盒、白盒設(shè)計測試用例9.1 白盒測試(結(jié)構(gòu)測試、邏輯驅(qū)動測試):9.1.1 語句覆蓋:設(shè)計若干個測試用例,使得被測試的程序中的每條可執(zhí)行語句至少被執(zhí)行一次9.1.2 判斷覆蓋:每個判斷至少都獲得一次“真”值和“假”值9.1.3 條件覆蓋:每個判斷中的條件可能的取值至少被執(zhí)行一次9.1.4 判斷與條件覆蓋:每個判斷的真假值分支至少被執(zhí)行一遍,并且每個判斷的條件的內(nèi)部判斷式的真假值分支也要被執(zhí)行一遍9.1.5 條件組合覆蓋:程序中每個判斷條件的內(nèi)部判斷式的各種真假值組合可能都至少執(zhí)行一遍9.1.6 路徑覆蓋:覆蓋程序中所有可能的路徑9.1.7 六種邏輯覆蓋從弱到強的

21、排列順序語句覆蓋-à判斷覆蓋-à條件覆蓋-à判斷條件覆蓋à條件組合覆蓋-à路徑覆蓋9.2 黑盒測試9.2.1 等價類劃分:有效等價類和無效等價類9.2.2 邊界值分析10 軟件項目管理:項目管理、五大過程、九大知識領(lǐng)域、項目三角形項目管理:是為完成一個預(yù)定的目標(biāo),而對任務(wù)和資源進行規(guī)劃、組織和管理的程序項目三角形:時間:反映在項目計劃中的項目完成所需時間。資金:即項目的預(yù)算,取決于資源的成本,這些資源包括完成任務(wù)所需的人員、設(shè)備和材料。范圍:項目的目標(biāo)和任務(wù),以及完成這些目標(biāo)和任務(wù)所需的工時。項目管理的五大過程:啟動過程、計劃過程、實施過程、控

22、制過程、收尾過程項目管理的九大知識領(lǐng)域:范圍管理、時間管理、成本管理、質(zhì)量管理、風(fēng)險管理、人力資源管理、溝通管理、采購管理、綜合管理11 配置管理:配置管理、配置管理項、基線、里程碑配置管理:是一組追蹤和控制活動,它們開始于軟件項目開始時,結(jié)束于軟件被淘汰之時。配置管理項:1。計算機程序-源代碼和可執(zhí)行程序2。描述計算機程序的文檔-供技術(shù)人員或用戶使用3。數(shù)據(jù)-程序內(nèi)包含的或在程序外的。每個配置項的主要屬性有名稱、標(biāo)識符、文件狀態(tài)、版本、作者、日期等基線:是一組配置項,這些配置項不能被隨便修改和變更。基線是軟件生存期中各開發(fā)階段末尾的特定點,又稱里程碑。軟件開發(fā)各階段的基線:12 結(jié)構(gòu)化方法與

23、面向?qū)ο蠓椒ǖ谋容^:基本思想;分階段比較1結(jié)構(gòu)化方法:基本思想:可以概括為自頂向下、逐步求精,采用模塊化技術(shù)和功能抽象將系統(tǒng)按功能分解為若干模塊,從而將復(fù)雜的系統(tǒng)分解成若干易于控制和處理的子系統(tǒng),子系統(tǒng)又可分解為更小的子任務(wù),最后的子任務(wù)都可以獨立編寫成子程序模塊,模塊內(nèi)部由順序、選擇、循環(huán)等基本控制結(jié)構(gòu)組成。2面向?qū)ο蠓椒ɑ舅枷耄好嫦驅(qū)ο蠓椒ǖ某霭l(fā)點和基本原則,是盡可能模擬人類習(xí)慣的思維方式,使開發(fā)軟件的方法與過程盡可能接近人類認識世界、解決問題的方法與過程,將客觀世界中的實體抽象為問題域中的對象。 使用現(xiàn)實的概念抽象地思考問題,從而自然地解決問題,保證軟件系統(tǒng)的穩(wěn)定性和可復(fù)用性以及良好的

24、維護性。 3 兩種方法的比較:傳統(tǒng)的結(jié)構(gòu)化方法,是軟件工程中最為成熟的方法。對于能夠預(yù)先確定需求的系統(tǒng)的開發(fā),采用結(jié)構(gòu)化方法非常有效,但是對于需求是模糊的或隨時間變化的系統(tǒng)開發(fā)這種方法不能適應(yīng)。面向?qū)ο蠓椒?,對于需求不能預(yù)先確定的系統(tǒng)的開發(fā),可采用面向?qū)ο蠓椒ńY(jié)合,這樣就能夠結(jié)合面向?qū)ο蠓椒ㄋ哂械姆€(wěn)定性好、可復(fù)用性好和可維護性好的特點。需求分析階段:結(jié)構(gòu)化方法:采用自頂向下功能分解的方法,強調(diào)邏輯功能而不是實現(xiàn)功能的具體方法,使用圖形進行系統(tǒng)分析并表達分析的結(jié)果-數(shù)據(jù)流圖,使用結(jié)構(gòu)化分析方法獲得的需求規(guī)格說明書由數(shù)據(jù)流圖、數(shù)據(jù)詞典及補充材料組成。面向?qū)ο蠓椒ǎ好嫦驅(qū)ο蠓治龅年P(guān)鍵是識別出問題域

25、中的對象,并分析它們之間的關(guān)系,最終建立起問題域的簡潔、精確、可理解的正確模型。面向?qū)ο蠓治瞿P屯ǔ0▽ο竽P?、動態(tài)模型和功能模型。對象模型是最重要、最基本、最核心的。設(shè)計階段:結(jié)構(gòu)化軟件是功能的集合,通過模塊調(diào)用實現(xiàn)系統(tǒng)。面向?qū)ο筌浖鞘挛锏募?通過對象及聯(lián)系實現(xiàn)系統(tǒng)。結(jié)構(gòu)化軟件=過程+數(shù)據(jù),以過程為中心。面向?qū)ο筌浖?數(shù)據(jù)+相應(yīng)操作,以數(shù)據(jù)為中心。結(jié)構(gòu)化軟件采用順序處理方式,由過程驅(qū)動控制;面向?qū)ο筌浖捎媒换ナ?、并行處理方?由消息驅(qū)動控制;結(jié)構(gòu)化方法的重點是設(shè)計;面向?qū)ο蠓椒ǖ闹攸c是分析。結(jié)構(gòu)化方法更適合數(shù)據(jù)類型比較簡單的軟件項目的開發(fā);面向?qū)ο蠓椒ǜm合大型復(fù)雜的軟件項目的開發(fā)練

26、習(xí)題:1. 看書上實例A,理解RUP過程2. 試討論RUP過程的優(yōu)缺點3. RUP過程主要適用于何種項目?4. 用面向?qū)ο蠓椒ㄩ_發(fā)軟件時與結(jié)構(gòu)化方法開發(fā)軟件時相比較,軟件的生命周期有何不同?這種差異帶來了什么后果?5. 為什么說廣州本田牌汽車是小汽車類的特化,而發(fā)動機不是小汽車類的特化?6. 什么是對象?它與傳統(tǒng)的數(shù)據(jù)有何區(qū)別?7. 試用面向?qū)ο蠓治龇椒ㄔO(shè)計下述程序:8. 在顯示器屏幕上圓心坐標(biāo)為(100,100)的位置畫一個半徑為40的圓,在圓心坐標(biāo)為(200,300)的位置畫一個半徑為20的圓,在圓心坐標(biāo)為( 400,150 )的位置畫一條弧,起始角為30度,結(jié)束角度為120度,半徑為50

27、.9. 思考題1、一個程序能夠既正確又不可靠嗎?請解釋你的答案。軟件可靠性是程序在給定的時間間隔內(nèi)按規(guī)格說明書的規(guī)定成功地運行的概率。軟件可靠性即包含正確性又包含健壯性。即程序在正常環(huán)境下應(yīng)能正確地完成預(yù)期功能,在意外環(huán)境下,也應(yīng)能作出適當(dāng)?shù)捻憫?yīng)。如果某程序在正常環(huán)境下可正常運行,在異常環(huán)境下不能作出適當(dāng)?shù)捻憫?yīng),則該項程序就是既正確又不可靠思考題2、為什么在開發(fā)軟件的過程中變化既是必要的又是不可避免的?為什么必須進行配置管理?在軟件開發(fā)過程中,下述原因會導(dǎo)致軟件配置項發(fā)生變化,新的市場條件導(dǎo)致需求或業(yè)務(wù)規(guī)則變化,客戶的需求也會或多或少地發(fā)生變化。企業(yè)改組或業(yè)務(wù)縮減,引起項目優(yōu)先級或軟件工程隊伍

28、結(jié)構(gòu)變化,預(yù)算或進度限制,導(dǎo)致對目標(biāo)系統(tǒng)的重新定義,發(fā)現(xiàn)了前期階段的錯誤,必須加以改正。因此,在開發(fā)軟件的過程中,變化既是必要的,又是不可避免的。如果不能適當(dāng)?shù)乜刂坪凸芾碜兓?,勢必造成混亂并產(chǎn)生許多嚴重的錯誤。軟件配置管理是在軟件的整個生命期內(nèi)管理變化的一組活動,可以認為軟件配置管理是應(yīng)用于整個軟件生命期的軟件質(zhì)量保證活動,是專門用于管理變化的軟件質(zhì)量保證活動,軟件配置管理的目標(biāo)是使變化更正確且更容易被適應(yīng),在必須變化時減少所需花費的工作量,綜上所述,進行配置管理是十分必要的3、某些軟件工程師不同意“目前國外許多軟件開發(fā)組織把60%以上的人力用于維護已有的軟件”的說法。他們爭論說:“我并沒有花費我的60%的時間去改正我所開發(fā)的程序中的錯誤”。請問,你對上述爭論有何看法?答:軟件維護并非僅僅是改正程序中的錯誤,它還包括適應(yīng)性維護、完善性維護

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論