《軟件工程》教學(xué)CH9-UML概述ppt課件_第1頁(yè)
《軟件工程》教學(xué)CH9-UML概述ppt課件_第2頁(yè)
《軟件工程》教學(xué)CH9-UML概述ppt課件_第3頁(yè)
《軟件工程》教學(xué)CH9-UML概述ppt課件_第4頁(yè)
《軟件工程》教學(xué)CH9-UML概述ppt課件_第5頁(yè)
已閱讀5頁(yè),還剩94頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、. UML面向?qū)ο蠓治雠c設(shè)計(jì)UML把Booch, Rumbaugh和Jacobson等各自獨(dú)立的OOA和OOD方法中最優(yōu)秀的特征組合成一個(gè)一致的方法。UML的特點(diǎn):一致規(guī)范面向?qū)ο罂梢暬?,表示才干?qiáng)大獨(dú)立于過(guò)程容易掌握運(yùn)用.UML的定義UML定義有兩個(gè)主要組成部分: 語(yǔ)義:用自然言語(yǔ)描畫 表示法:定義UML的可視化規(guī)范表示符號(hào)運(yùn)用 UML 時(shí),要從不同的角度察看系統(tǒng),為此定義了概念 “視圖。視圖是對(duì)系統(tǒng)的模型在某方面的投影,注重于系統(tǒng)的某個(gè)方面。.構(gòu)造視圖行為視圖實(shí)現(xiàn)視圖環(huán)境視圖用例視圖為最終用戶做什么系統(tǒng)靜態(tài)構(gòu)造程序員提供什么軟件組織與管理系統(tǒng)集成人員如何組織與控制系統(tǒng)系統(tǒng)工程師如何配置和運(yùn)

2、轉(zhuǎn)系統(tǒng)系統(tǒng)拓?fù)?、交付、安裝、操作、通訊分析員或測(cè)試員系統(tǒng)義務(wù)控制與管理(性能,可伸縮性,吞吐量)行為.構(gòu)造視圖:描畫系統(tǒng)的靜態(tài)構(gòu)造,可根據(jù)它確定重要的設(shè)計(jì):類、包和子系統(tǒng)。實(shí)現(xiàn)視圖:描畫處于開(kāi)發(fā)環(huán)境中的靜態(tài)軟件成分的組織源程序、構(gòu)件、數(shù)據(jù)文件、可執(zhí)行程序等。行為視圖:描畫系統(tǒng)在運(yùn)轉(zhuǎn)時(shí)的并發(fā)性,包括義務(wù)、線程、進(jìn)程及其相互作用。軟件體系構(gòu)造的 4+1 視圖模型.環(huán)境視圖:描畫處于運(yùn)轉(zhuǎn)環(huán)境中的各種可執(zhí)行程序是如何映射究竟層平臺(tái)或計(jì)算結(jié)點(diǎn)上的。用例視圖:包括假設(shè)干關(guān)鍵場(chǎng)景或用例。在初始和細(xì)化階段用來(lái)協(xié)助發(fā)現(xiàn)和設(shè)計(jì)體系構(gòu)造。在構(gòu)造階段用來(lái)驗(yàn)證各種不同視圖。在文檔中用來(lái)闡明其他視圖是如何任務(wù)的。UML分

3、析建模著重系統(tǒng)的用例模型和構(gòu)造模型,設(shè)計(jì)建模著重行為模型,實(shí)現(xiàn)模型和環(huán)境模型上。.體系構(gòu)造中主要的元素包括: 主要的類,如為業(yè)務(wù)虛體建模的類。 將行為賦予類的機(jī)制,如協(xié)同。 方式與框架。 層次與子系統(tǒng)。 接口以及主要的進(jìn)程控制或線程控制。UML 的三個(gè)主要組成元素 根本構(gòu)造塊 組織構(gòu)造塊的規(guī)那么 運(yùn)用于整個(gè) UML 的公共機(jī)制.UML的構(gòu)成UML包括三種根本構(gòu)造塊:事物、關(guān)系和圖。UML事物構(gòu)造事物 類名屬性操作open( )close( )move( )display( )originsizeWindow類.接口 描畫一個(gè)類或構(gòu)件的效力操作。協(xié)作 描畫協(xié)作完成某個(gè)特定義務(wù)的一組類及其關(guān)聯(lián)的集

4、合,用于對(duì)運(yùn)用情形的實(shí)現(xiàn)建模。用例 表示系統(tǒng)想要實(shí)現(xiàn)的行為,不關(guān)懷這些行為是怎樣實(shí)現(xiàn)的。ISpelling.Place OrderOrderManagement用例協(xié)作實(shí)現(xiàn)自動(dòng)類 它至少擁有一個(gè)進(jìn)程或線程,故可以啟動(dòng)控制活動(dòng)。 suspend()flush()EventManager.構(gòu)件 系統(tǒng)中物理 的、可替代的部件。節(jié)點(diǎn) 系統(tǒng)在運(yùn)轉(zhuǎn) 時(shí)存在的物理元素。Orderform.java數(shù)據(jù)庫(kù)效力器運(yùn)用效力器課程管理成果管理.UML 事物行為事物交互 由在特定環(huán)境中共同完成一定義務(wù)的一組對(duì)象之間交換的音訊組成。p:Person:CompanyAssign(development)音訊有名對(duì)象匿名對(duì)

5、象.形狀機(jī) 描畫了一個(gè)對(duì)象或一個(gè)交互在生存周期內(nèi)呼應(yīng)事件所閱歷的形狀序列。initializingcommandidleKeypressFinishedExit.UML 事物分組事物包用戶接口包業(yè)務(wù)對(duì)象包數(shù)據(jù)庫(kù)包運(yùn)用包.UML 事物注釋事物注釋 依靠于一個(gè)元素或一組元素之上,對(duì)其進(jìn)展約束或解釋的簡(jiǎn)單符號(hào)。CashAccountpresentValue()See policy8-5-96.doc for details about these algorithms.UML 關(guān)系依賴 兩個(gè)事物之間的語(yǔ)義關(guān)系,其中一個(gè)事物發(fā)生變化會(huì)影響另一個(gè)事物的語(yǔ)義。CourseScheduleadd(c:Cou

6、rse)remove(c:Course)CourseIterator.關(guān)聯(lián) 一種描畫一組對(duì)象之間銜接的構(gòu)造關(guān)系。聚合是一種特殊類型的關(guān)聯(lián),描畫了整體和部分間的構(gòu)造關(guān)系。泛化 一種普通化特殊化的關(guān)系。employeremployee0.1*.EventConsoleWindowDialogBoxControl依賴泛化關(guān)聯(lián) Windowopen()close()move()display()handleEvent().實(shí)現(xiàn) 類之間的語(yǔ)義關(guān)系,其中的一個(gè)類指定了由另一個(gè)類保證執(zhí)行的契約。 兩種情況出現(xiàn)實(shí)現(xiàn)關(guān)系:在接口和實(shí)現(xiàn)它們的類或構(gòu)件之間;用例和它們的協(xié)作之間。Place OrderOrderMa

7、nagement用例協(xié)作實(shí)現(xiàn).類屬性操作對(duì)象屬性操作接口用例構(gòu)件節(jié)點(diǎn)形狀機(jī)包注釋依賴關(guān)聯(lián)泛化實(shí)現(xiàn)聚合復(fù)合 模型中主要的圖形元素.UML 模型的圖形Use CaseDiagramsUse CaseDiagrams用例圖ScenarioDiagramsScenarioDiagrams協(xié)作圖StateDiagramsStateDiagrams構(gòu)件圖ComponentDiagramsComponentDiagrams部署圖StateDiagramsStateDiagrams對(duì)象圖ScenarioDiagramsScenarioDiagrams形狀圖Use CaseDiagramsUse CaseDia

8、grams順序圖StateDiagramsStateDiagrams類圖活動(dòng)圖模型.1. 用例圖用例圖展現(xiàn)了一組用例、參與者以及它們間的關(guān)系??梢杂糜美龍D描畫系統(tǒng)的靜態(tài)運(yùn)用情況,它定義了系統(tǒng)的功能需求,但這是從系統(tǒng)的外部觀看系統(tǒng)功能,并不描畫系統(tǒng)內(nèi)部對(duì)功能的詳細(xì)實(shí)現(xiàn)。在對(duì)系統(tǒng)行為組織和建模方面,用例圖的是相當(dāng)重要的。.查詢商品價(jià)錢顧客庫(kù)存系統(tǒng)售貨員總賬系統(tǒng)查詢商品信息預(yù)售商品網(wǎng)上銷售商品打折銷售商品出賣商品查詢商品成分商品查詢售貨管理.說(shuō)明顧客持所欲購(gòu)買的商品至收銀臺(tái)結(jié)帳,店員刷商品條碼后,根據(jù)數(shù)量及單價(jià)計(jì)算總金額商品售出后,商品編碼、單價(jià)、總金額存入電腦,數(shù)據(jù)記載到“庫(kù)存系統(tǒng)”和“總帳系統(tǒng)”

9、中(含預(yù)售、網(wǎng)絡(luò)購(gòu)物、打折銷售)。事件流基本事件流刷條碼? 結(jié)算金額?付款?扣庫(kù)存?記入日記賬?打印發(fā)票異常事件流 第一異常事件流顧客結(jié)帳后更換商品 第二異常事件流顧客將已售商品退回特殊需求 第一個(gè)特殊需求允許退貨, 并將退回商品加回庫(kù)存 第二個(gè)特殊需求記錄顧客的性別,年齡,供后續(xù)統(tǒng)計(jì)分析用用例規(guī)格闡明:銷售商品.2. 類圖類圖展現(xiàn)了一組類、接口和協(xié)作及它們間的關(guān)系。類圖沒(méi)有時(shí)間概念,是概念數(shù)據(jù)模型如E-R 圖的一種延伸。用類圖闡明系統(tǒng)的靜態(tài)構(gòu)造視圖,包含自動(dòng)類的類圖專注于系統(tǒng)的靜態(tài)處置視圖。系統(tǒng)可有多個(gè)類圖,單個(gè)類圖僅表達(dá)了系統(tǒng)的一個(gè)方面,要在高層給出類的主要職責(zé),在低層給出類的屬性和操作。

10、.類圖是從系統(tǒng)構(gòu)成角度來(lái)描畫系統(tǒng)。類的表示:類的稱號(hào)屬性屬性 :數(shù)據(jù)類型屬性 :數(shù)據(jù)類型 = 初值操作操作(參數(shù)表):結(jié)果類型.限定關(guān)聯(lián)類1類2限定詞關(guān)聯(lián)稱號(hào)角色1角色2聚合、援用和反復(fù)度0.*0.10.*整體 類名部分 類名2部分 類名10.1聚合簡(jiǎn)單援用復(fù)合聚合雙方捆綁.關(guān)聯(lián)名類 1類 2關(guān)聯(lián)類名屬性操作角色 1角色 2關(guān)聯(lián)類.泛化關(guān)系超類子類1子類2操作籠統(tǒng)類操作.雇員雇員標(biāo)識(shí): char姓名: char職務(wù): char工資: long工程工程標(biāo)識(shí)工程稱號(hào)參與開(kāi)場(chǎng)日期終了日期義務(wù)義務(wù)標(biāo)識(shí)義務(wù)稱號(hào)義務(wù)費(fèi)用技藝技藝標(biāo)識(shí)技藝稱號(hào)團(tuán)隊(duì)團(tuán)隊(duì)標(biāo)識(shí)承當(dāng)任務(wù)部門部門標(biāo)識(shí)部門稱號(hào)客戶客戶標(biāo)識(shí)客戶稱號(hào)客戶地

11、址客戶客戶代表0.*0.*10.*1.*10.*1.*1.*110.*11.*0.*1.*.3. 對(duì)象圖對(duì)象圖展現(xiàn)了一組對(duì)象及它們間的關(guān)系。用對(duì)象圖闡明類圖中類的對(duì)象實(shí)例的數(shù)據(jù)構(gòu)造和靜態(tài)快照,即在某一時(shí)辰,一組對(duì)象的形狀及其關(guān)系。對(duì)象圖表達(dá)了系統(tǒng)的靜態(tài)設(shè)計(jì)視圖或靜態(tài)過(guò)程視圖,除了現(xiàn)實(shí)和原型的方面要素外,它與類圖作用是一樣的。.c: 公司稱號(hào)=“研發(fā)d2: 部門d1: 部門稱號(hào)=“銷售d3: 部門稱號(hào)=“打印機(jī)銷售 : 聯(lián)絡(luò)信息地址=“清華產(chǎn)業(yè)樓411p: 人員姓名=“鄭人杰雇員標(biāo)識(shí)=6037職務(wù)=“銷售副總經(jīng)理銜接 link屬性值對(duì)象匿名對(duì)象.4. 包圖 包圖闡明包及其之間的依賴類圖。包是對(duì)模

12、型中涉及的元素分組所得的結(jié)果,是具有特定語(yǔ)義的一個(gè)子集,必需保證低耦合、高內(nèi)聚。廣義地講,包可以包含類、接口、構(gòu)件、節(jié)點(diǎn)、協(xié)作、用例等,還可以內(nèi)嵌其他子包。包之間的訪問(wèn)權(quán)限經(jīng)過(guò)輸出輸出品和導(dǎo)入進(jìn)口貨設(shè)置,虛箭頭 從源包到目的包。.5. 構(gòu)件圖構(gòu)件圖展現(xiàn)了一組構(gòu)件之間的組織和依賴,用于對(duì)源代碼、可執(zhí)行的發(fā)布、物理數(shù)據(jù)庫(kù)等的系統(tǒng)建模。構(gòu)件圖表示系統(tǒng)的靜態(tài)實(shí)現(xiàn)視圖。.CourseCourseOfferingStudentProfessorCourse.dllPeople.dll課程用戶Register.exeBilling.exe課表系統(tǒng).6. 部署圖部署圖展現(xiàn)了對(duì)運(yùn)轉(zhuǎn)時(shí)處置節(jié)點(diǎn)以及其中構(gòu)件的配置每

13、一節(jié)點(diǎn)代表一個(gè)計(jì)算單元。它描畫系統(tǒng)硬件的物理拓?fù)錁?gòu)造 ( 包括網(wǎng)絡(luò)規(guī)劃和構(gòu)件在網(wǎng)絡(luò)上的位置) ,以及在此構(gòu)造上執(zhí)行的軟件即運(yùn)轉(zhuǎn)時(shí)軟構(gòu)件在節(jié)點(diǎn)中的分布情況。用部署圖闡明系統(tǒng)構(gòu)造的靜態(tài)環(huán)境視圖,即闡明分布、交付和安裝的物理系統(tǒng)。.注冊(cè)效力器數(shù)據(jù)庫(kù)宿舍客戶機(jī)圖書館客戶機(jī)主排課客戶機(jī).8. 活動(dòng)圖活動(dòng)圖是一種特殊的形狀圖,描畫要做的活動(dòng)、執(zhí)行這些活動(dòng)的順序以及任務(wù)流。它對(duì)于系統(tǒng)的功能建模特別重要,強(qiáng)調(diào)對(duì)象間的控制流程。高層活動(dòng)圖用于表示義務(wù)。即用于分析用例,了解涉及多個(gè)用例的任務(wù)流、多線程及并行,顯示相互聯(lián)絡(luò)的行為整體,還可用于業(yè)務(wù)過(guò)程建模,對(duì)系統(tǒng)的功能建模。低層活動(dòng)圖用于表示類的方法。.按訂單供貨接

14、訂單開(kāi)發(fā)票結(jié)清訂單快速交付正常交付收款起點(diǎn)分叉活動(dòng)分支合并集合終了緊急訂單非緊急訂單變化.9. 形狀圖形狀圖展現(xiàn)了一個(gè)特定對(duì)象的一切能夠形狀以及由于各種事件的發(fā)生而引起的形狀間的轉(zhuǎn)移。一個(gè)形狀圖描畫了一個(gè)形狀機(jī),用形狀圖闡明系統(tǒng)的動(dòng)態(tài)視圖。形狀圖對(duì)于接口、類或協(xié)作的行為建模尤為重要,可用它描畫用例實(shí)例的生存周期。.Project對(duì)象的形狀圖注冊(cè)預(yù)售開(kāi)發(fā)系統(tǒng)分析系統(tǒng)設(shè)計(jì)程序編碼軟件測(cè)試系統(tǒng)部署單元測(cè)試與調(diào)試維護(hù)新projectproject完開(kāi)場(chǎng)終了.10. 交互圖交互圖展現(xiàn)了按一定的目的進(jìn)展一種交互,它由在一個(gè)上下文中的一組對(duì)象及它們之間交互的信息組成。交互圖可用于描畫一個(gè)用例的行為。順序圖和

15、協(xié)作圖都是交互圖,它們可以相互轉(zhuǎn)換。假設(shè)希望查看單個(gè)對(duì)象跨用例的行為, 要運(yùn)用形狀圖。假設(shè)希望查看跨用例跨線程的行為,要運(yùn)用活動(dòng)圖。.10-1 順序圖順序圖展現(xiàn)了一組對(duì)象和由這組對(duì)象收發(fā)的音訊,用于按時(shí)間順序?qū)刂屏鹘!?duì)象表述為虛垂線頂端的矩形小框。垂線是對(duì)象的生命線,闡明對(duì)象的生命。生命線之間的箭頭表示音訊。音訊出現(xiàn)的次序自上而下。音訊箭頭可以回到同一條生命線,指明自調(diào)用,即對(duì)象發(fā)給本人的音訊。.挪動(dòng)系統(tǒng)的用例圖挪動(dòng)用戶挪動(dòng)網(wǎng)絡(luò)與對(duì)方通話下載圖符下載鈴聲管理本.挪動(dòng)系統(tǒng)的順序圖 : 挪動(dòng)用戶 : 挪動(dòng)按鍵 : 挪動(dòng)顯示 : 挪動(dòng)手機(jī) : 挪動(dòng)基站按數(shù)字鍵顯示按鍵號(hào)碼按發(fā)送鍵銜接基站建立銜

16、接銜接勝利顯示銜接勝利.10-2 協(xié)作圖協(xié)作圖展現(xiàn)了一組對(duì)象,這組對(duì)象之間的銜接以及這組對(duì)象收發(fā)的音訊。它強(qiáng)調(diào)收發(fā)音訊的對(duì)象構(gòu)造組織,按組織構(gòu)造對(duì)控制流建模。協(xié)作圖中的協(xié)作不是參與者與系統(tǒng)之間的交互,而是系統(tǒng)內(nèi)部某一個(gè)用例中各個(gè)對(duì)象之間信息傳送的方式。音訊上所附編號(hào)指明執(zhí)行順序。.挪動(dòng)系統(tǒng)的協(xié)作圖 : 挪動(dòng)用戶1: 按數(shù)字鍵3: 按發(fā)送鍵 : 挪動(dòng)按鍵2: 顯示按鍵號(hào)碼 : 挪動(dòng)顯示 : 挪動(dòng)手機(jī) : 挪動(dòng)基站4: 銜接基站5: 建立銜接6: 銜接勝利7: 顯示銜接勝利. *RUPRational Unified Process一致開(kāi)發(fā)過(guò)程的分析/設(shè)計(jì)任務(wù)流分析和設(shè)計(jì)任務(wù)流的目的是研討欲采用的

17、實(shí)現(xiàn)環(huán)境和系統(tǒng)構(gòu)件的成效,定義軟件的組織構(gòu)造,把需求獲取結(jié)果轉(zhuǎn)化為實(shí)現(xiàn)規(guī)格。為實(shí)現(xiàn)這種轉(zhuǎn)化,必需了解需求,采用最正確實(shí)現(xiàn)戰(zhàn)略將其翻譯為系統(tǒng)設(shè)計(jì)。為此,首先是建立強(qiáng)壯的軟件體系構(gòu)造,設(shè)計(jì)出易于了解、開(kāi)發(fā)和演進(jìn)的系統(tǒng),然后調(diào)整這個(gè)設(shè)計(jì),使之順應(yīng)實(shí)現(xiàn)環(huán)境。最后結(jié)果是產(chǎn)生一個(gè)對(duì)象模型,即設(shè)計(jì)模型。.定義初始體系構(gòu)造早期細(xì)化迭代分析行為設(shè)計(jì)實(shí)時(shí)構(gòu)件設(shè)計(jì)數(shù)據(jù)庫(kù)設(shè)計(jì)構(gòu)件細(xì)化體系構(gòu)造細(xì)化迭代可選實(shí)時(shí)非實(shí)時(shí).定義一個(gè)初始的體系構(gòu)造建立一個(gè)初始的系統(tǒng)體系構(gòu)造草圖。定義一組初始的重要體系構(gòu)造元素。一組初始分析機(jī)制。系統(tǒng)的初始分層和組織。在當(dāng)前迭代過(guò)程中處置的用例實(shí)現(xiàn)。從重要的構(gòu)件用例中確定類。確定類之間的交互作用,

18、修正用例實(shí)現(xiàn)。細(xì)化體系構(gòu)造.建立從分析到設(shè)計(jì)的自然轉(zhuǎn)移,并標(biāo)識(shí):從分析元素中確定適當(dāng)?shù)脑O(shè)計(jì)元素。從相關(guān)分析機(jī)制中確定適當(dāng)?shù)脑O(shè)計(jì)機(jī)制。堅(jiān)持體系構(gòu)造的一致性和完好性,確保:將當(dāng)前迭代中標(biāo)識(shí)的新的設(shè)計(jì)元素與已有的設(shè)計(jì)元素集成在一同。在設(shè)計(jì)中盡早地、最大限制地復(fù)用可獲得的構(gòu)件和設(shè)計(jì)元素。描畫系統(tǒng)運(yùn)轉(zhuǎn)的組織和實(shí)施體系構(gòu)造。組織實(shí)現(xiàn)模型以實(shí)現(xiàn)設(shè)計(jì)到實(shí)現(xiàn)無(wú)縫轉(zhuǎn)移。.分析行為將用例提供的行為描畫轉(zhuǎn)變?yōu)橐幌盗锌勺鳛樵O(shè)計(jì)根底的元素。在分析行為時(shí),主要注重于如何可以提供要求的功能,較少關(guān)懷系統(tǒng)的非功能需求。設(shè)計(jì)構(gòu)件找出設(shè)計(jì)元素如何實(shí)現(xiàn)要求行為的細(xì)節(jié),細(xì)化設(shè)計(jì)元素的定義。根據(jù)新的設(shè)計(jì)元素來(lái)細(xì)化和更新用例實(shí)現(xiàn)。當(dāng)設(shè)計(jì)演

19、進(jìn)后,進(jìn)展設(shè)計(jì)評(píng)審。.設(shè)計(jì)實(shí)時(shí)構(gòu)件在實(shí)時(shí)的或交互式的上下文中,運(yùn)用封裝制品作為主要的設(shè)計(jì)元素。設(shè)計(jì)實(shí)時(shí)構(gòu)件與設(shè)計(jì)構(gòu)件有類似的活動(dòng),但添加了封裝設(shè)計(jì)活動(dòng),定義系統(tǒng)的并發(fā)控制線程和它們之間的協(xié)議。設(shè)計(jì)數(shù)據(jù)庫(kù)在設(shè)計(jì)中標(biāo)識(shí)永久類并設(shè)計(jì)適當(dāng)?shù)臄?shù)據(jù)庫(kù)構(gòu)造來(lái)存儲(chǔ)永久類。定義一種存儲(chǔ)和檢索永久數(shù)據(jù)的機(jī)制和戰(zhàn)略,以滿足系統(tǒng)的性能需求。.分析和設(shè)計(jì)任務(wù)流中的關(guān)鍵制品:設(shè)計(jì)模型 由類的協(xié)作構(gòu)成。這些類的協(xié)作能夠集成為包或子系統(tǒng)。包是對(duì)類的邏輯分組,是為了減少系統(tǒng)的復(fù)雜性。 分析模型 是設(shè)計(jì)的籠統(tǒng)和泛化,它提供系統(tǒng)的功能描畫,忽略了系統(tǒng)如何任務(wù)的細(xì)節(jié)。 軟件體系構(gòu)造文檔 涵蓋系統(tǒng)不同的體系構(gòu)造視圖。.實(shí)現(xiàn)任務(wù)流實(shí)現(xiàn)任

20、務(wù)流的目的是 建立代碼的分層構(gòu)造; 從構(gòu)件源文件、二進(jìn)制文件、可執(zhí)行文件或其他文件角度來(lái)實(shí)現(xiàn)類和對(duì)象; 對(duì)開(kāi)發(fā)出來(lái)的構(gòu)件進(jìn)展單元測(cè)試; 將個(gè)人和開(kāi)發(fā)團(tuán)隊(duì)開(kāi)發(fā)的結(jié)果集成到可執(zhí)行系統(tǒng)中。單元測(cè)試僅對(duì)單個(gè)構(gòu)件進(jìn)展。集成測(cè)試和系統(tǒng)測(cè)試在測(cè)試任務(wù)流中執(zhí)行。.構(gòu)造實(shí)現(xiàn)模型集成每個(gè)子系統(tǒng)集成系統(tǒng)制定集成方案實(shí)現(xiàn)構(gòu)件可用于單元測(cè)試的構(gòu)件可用于集成的實(shí)現(xiàn)子系統(tǒng)針對(duì)這個(gè) 迭代過(guò)程 的更多的 系統(tǒng)構(gòu)造針對(duì)這 個(gè)迭代 過(guò)程的 更多的 子系統(tǒng)構(gòu)造針對(duì)這個(gè) 迭代過(guò)程 的更多的 要實(shí)現(xiàn)的構(gòu)件.實(shí)現(xiàn)模型是在細(xì)化階段經(jīng)過(guò)不斷迭代,不斷運(yùn)用更大規(guī)模的集成構(gòu)造建立起來(lái)的。對(duì)于每一次迭代,要求做到:確定要實(shí)現(xiàn)哪一個(gè)子系統(tǒng),以及在當(dāng)前

21、迭代中子系統(tǒng)的集成順序。對(duì)于每一個(gè)子系統(tǒng),確定實(shí)現(xiàn)每個(gè)類的順序,以及子系統(tǒng)集成的方案。實(shí)現(xiàn)設(shè)計(jì)模型中的類和對(duì)象,包括編寫源代碼、改寫已有構(gòu)件、編譯、鏈接和執(zhí)行,及時(shí)反響設(shè)計(jì)中能夠的缺陷。.修正有缺陷的源代碼,進(jìn)展單元測(cè)試以驗(yàn)證這些變卦。最后進(jìn)展代碼評(píng)審。指定專人擔(dān)任將一切新的和已變卦的構(gòu)件集成為一個(gè)新的實(shí)現(xiàn)子系統(tǒng)版本。在團(tuán)隊(duì)環(huán)境,集成將產(chǎn)生一系列構(gòu)造,對(duì)每個(gè)構(gòu)造由集成測(cè)試員進(jìn)展集成測(cè)試。將發(fā)布的子系統(tǒng)集成到系統(tǒng)。最終的構(gòu)造即為系統(tǒng)。由系統(tǒng)測(cè)試員進(jìn)展系統(tǒng)測(cè)試。.實(shí)現(xiàn)任務(wù)流的關(guān)鍵制品有:實(shí)現(xiàn)子系統(tǒng) 構(gòu)件和其他實(shí)現(xiàn)子系統(tǒng)的集成。它是將實(shí)現(xiàn)模型細(xì)分為更小的部分,并使其構(gòu)造化。構(gòu)件 可以是一塊程序代碼,

22、或是包含信息的文件。構(gòu)件可以由其他構(gòu)件聚合而成。集成構(gòu)造方案 定義構(gòu)件和子系統(tǒng)的實(shí)現(xiàn)順序,詳細(xì)描畫系統(tǒng)集成時(shí)要建立的構(gòu)造。實(shí)現(xiàn)與設(shè)計(jì)的關(guān)系嚴(yán)密。在設(shè)計(jì)元素和實(shí)現(xiàn)元素之間有非常明顯的跟蹤鏈接。.創(chuàng)建良好設(shè)計(jì)的原那么設(shè)計(jì)原那么1:分治軟件系統(tǒng)分解為子系統(tǒng) 分布式系統(tǒng)可以分解為客戶機(jī)和效力器; 系統(tǒng)可以分解為一系列子系統(tǒng);子系統(tǒng)可以分解為一個(gè)或多個(gè)包;包可以分解為類;類可以分解為方法。.設(shè)計(jì)原那么2:盡能夠添加內(nèi)聚不同內(nèi)聚類型:優(yōu)先級(jí)從高到低排序功能內(nèi)聚:模塊只執(zhí)行單一計(jì)算并前往結(jié)果,沒(méi)有副作用。如函數(shù)過(guò)程。層內(nèi)聚:相關(guān)效力放在一同,并有嚴(yán)厲的層次構(gòu)造,高層效力可訪問(wèn)低層效力,反之不可。如分層構(gòu)造。

23、通訊內(nèi)聚:訪問(wèn)或操作同一數(shù)據(jù)的過(guò)程放在一個(gè)類中,這些過(guò)程可以相互通訊。如某個(gè)類設(shè)計(jì)。.順序內(nèi)聚:存在一系列過(guò)程,其中一個(gè)過(guò)程向另一個(gè)過(guò)程提供輸入,這些過(guò)程放在一同,構(gòu)成順序內(nèi)聚。如音訊序列。過(guò)程內(nèi)聚:幾個(gè)一次調(diào)用的過(guò)程放在一同,但其中一個(gè)過(guò)程的輸出不一定是另一個(gè)過(guò)程的輸入,構(gòu)成過(guò)程內(nèi)聚。如調(diào)用構(gòu)造。時(shí)間內(nèi)聚:程序執(zhí)行過(guò)程中同一階段內(nèi)完成的操作放在一同,到達(dá)時(shí)間內(nèi)聚。適用程序內(nèi)聚:邏輯上不能納入其他內(nèi)聚類型的相關(guān)適用程序放在一同,構(gòu)成適用程序內(nèi)聚。如可復(fù)用的過(guò)程或類。.設(shè)計(jì)原那么3:盡能夠降低耦合模塊間存在相互依賴關(guān)系即為耦合。不同耦合類型從高向低陳列有:內(nèi)容耦合:一個(gè)構(gòu)件在不被覺(jué)察的情況下修正

24、另一個(gè)構(gòu)件內(nèi)部的數(shù)據(jù),應(yīng)一直防止。公共耦合:一組構(gòu)件運(yùn)用了全局?jǐn)?shù)據(jù),就產(chǎn)生公共耦合。應(yīng)經(jīng)過(guò)封裝降低公共耦合。控制耦合:一個(gè)過(guò)程經(jīng)過(guò)標(biāo)志、開(kāi)關(guān)或命令顯式地控制另一個(gè)過(guò)程的動(dòng)作,就產(chǎn)生控制耦合。降低的方法是采用多態(tài)操作。.標(biāo)志耦合:在一個(gè)操作的參數(shù)表中將類作為參數(shù),就產(chǎn)生標(biāo)志耦合。降低標(biāo)志耦合的方法可以傳送簡(jiǎn)單變量或運(yùn)用接口做參數(shù)。數(shù)據(jù)耦合:在一個(gè)操作的參數(shù)表中用簡(jiǎn)單變量或簡(jiǎn)單的類如string作為參數(shù),就產(chǎn)生數(shù)據(jù)耦合。應(yīng)經(jīng)過(guò)減少參數(shù)個(gè)數(shù)降低耦合。例程調(diào)用耦合:一個(gè)例程或類操作調(diào)用另一個(gè)例程,就產(chǎn)生例程調(diào)用耦合。假設(shè)出現(xiàn)例程調(diào)用序列,降低的方法是編寫一個(gè)例程將這個(gè)調(diào)用序列封裝起來(lái)。.類型運(yùn)用耦合:

25、類將實(shí)例變量或本地變量聲明為另一個(gè)類時(shí),就產(chǎn)生類型嵌套運(yùn)用耦合。降低該耦合的方法是將變量的類型聲明為包含所需操作的最通用的類或接口。包含/引入耦合:當(dāng)一個(gè)構(gòu)件引入import一個(gè)包時(shí)就產(chǎn)生引入耦合,當(dāng)一個(gè)構(gòu)件包含include另一個(gè)構(gòu)件時(shí),就產(chǎn)生包含耦合。外部耦合:模塊對(duì)外部系統(tǒng),如操作系統(tǒng)、共享庫(kù)或硬件有依賴關(guān)系時(shí)就產(chǎn)生外部耦合??山?jīng)過(guò)信息隱蔽減少這種依賴關(guān)系。.設(shè)計(jì)原那么4:盡能夠提高籠統(tǒng)層次設(shè)計(jì)應(yīng)隱藏或推遲思索細(xì)節(jié)以降低復(fù)雜性。類是包含過(guò)程籠統(tǒng)的數(shù)據(jù)籠統(tǒng)。父類和接口可進(jìn)一步提高籠統(tǒng)層次。類中公有操作越少,籠統(tǒng)程度越高。類中一切變量都是私有,籠統(tǒng)程度到達(dá)最高?;\統(tǒng)可確保在設(shè)計(jì)時(shí)不用關(guān)懷不用

26、要的細(xì)節(jié),能把握問(wèn)題的本質(zhì)并做出重要的決策。設(shè)計(jì)原那么5:盡能夠提高可復(fù)用性.可以在算法、類、過(guò)程、框架和完好運(yùn)用程序的級(jí)別上創(chuàng)建可復(fù)用性。復(fù)用構(gòu)件的機(jī)制包括過(guò)程調(diào)用和承繼父類。設(shè)計(jì)原那么6:盡能夠復(fù)用已有的設(shè)計(jì)和代碼復(fù)用已有的設(shè)計(jì)是對(duì)可復(fù)用性設(shè)計(jì)的補(bǔ)充。經(jīng)過(guò)復(fù)用可從以往對(duì)可復(fù)用構(gòu)件的投資中獲益。設(shè)計(jì)原那么7:靈敏性設(shè)計(jì)積極預(yù)測(cè)未來(lái)能夠在實(shí)現(xiàn)和功能上的變化,并為此采取相應(yīng)措施。.在設(shè)計(jì)中引入靈敏性的方法有: 降低耦合并提高內(nèi)聚易于提高交換才干 建立籠統(tǒng)創(chuàng)建有多態(tài)操作的接口和父類 不要將代碼寫死消除代碼中的常數(shù) 拋出異常由操作的調(diào)用者處置異常 運(yùn)用并創(chuàng)建可復(fù)用的代碼設(shè)計(jì)原那么8:估計(jì)過(guò)期積極預(yù)測(cè)

27、未來(lái)能夠在技術(shù)和運(yùn)轉(zhuǎn)環(huán)境上的變化,并為此采取相應(yīng)措施。.在設(shè)計(jì)中應(yīng)遵照的估計(jì)過(guò)期的規(guī)那么有: 防止運(yùn)用早期發(fā)布的技術(shù) 防止運(yùn)用針對(duì)特定環(huán)境的軟件庫(kù) 防止運(yùn)用軟件庫(kù)中未編檔的或很少運(yùn)用的功能 防止運(yùn)用小公司或能夠不提供長(zhǎng)期支持的公司提供的可復(fù)用構(gòu)件或特殊硬件 運(yùn)用眾多廠商支持的規(guī)范言語(yǔ)和技術(shù)設(shè)計(jì)原那么9:可移植性設(shè)計(jì).可移植性設(shè)計(jì)的主要目的是讓軟件在盡能夠多的平臺(tái)上運(yùn)轉(zhuǎn)。實(shí)現(xiàn)可移植性的規(guī)那么有: 防止運(yùn)用特定環(huán)境的專有功能 運(yùn)用不依賴特定平臺(tái)的程序設(shè)計(jì)言語(yǔ) 小心運(yùn)用能夠依賴某一平臺(tái)的類庫(kù) 了解其他言語(yǔ)能夠依賴特殊硬件構(gòu)造的功能和文本文件的差別設(shè)計(jì)原那么10:可測(cè)試性設(shè)計(jì)設(shè)計(jì)時(shí)采取措施使得測(cè)試易于

28、進(jìn)展。.可測(cè)試性設(shè)計(jì)的最重要的方法是保證代碼的一切功能都能脫離圖形用戶界面執(zhí)行設(shè)計(jì)原那么11:防御性設(shè)計(jì)為提高可靠性,應(yīng)確保不引入任何缺陷,可以處置其他代碼不適當(dāng)運(yùn)用構(gòu)件引起的問(wèn)題。按契約設(shè)計(jì)是防御性設(shè)計(jì)技術(shù),其中心思想: 被調(diào)用操作為正常執(zhí)行必需滿足的前置條件(precondition):調(diào)用操作在調(diào)用一個(gè)操作時(shí)有責(zé)任確保該操作的前置條件成立。 . 被調(diào)用操作正常執(zhí)行所得到的結(jié)果即為后置條件 (postcongdition):要求被調(diào)用操作在前往前有責(zé)任保證這些后置條件成立。 被調(diào)用操作在執(zhí)行時(shí)確保不會(huì)被修正的不變量(invariant)。前置條件、后置條件和不變式都是布爾表達(dá)式,其計(jì)算結(jié)果

29、為假,表示有錯(cuò)誤發(fā)生??梢赃\(yùn)用斷言機(jī)制。在重要構(gòu)件的邊境如層應(yīng)一直保管嚴(yán)厲的斷言檢測(cè)。.設(shè)計(jì)方式設(shè)計(jì)方式是面向?qū)ο筌浖O(shè)計(jì)閱歷的總結(jié)。設(shè)計(jì)方式系統(tǒng)地命名、解釋和評(píng)價(jià)了面向?qū)ο笙到y(tǒng)中的一個(gè)重要的和反復(fù)出現(xiàn)的設(shè)計(jì)。設(shè)計(jì)方式使人們可以簡(jiǎn)一方便地復(fù)用勝利的設(shè)計(jì)和體系構(gòu)造。設(shè)計(jì)方式描畫了在特定場(chǎng)景下運(yùn)用的處理普通設(shè)計(jì)問(wèn)題的類和相互通訊的對(duì)象。.設(shè)計(jì)方式的四個(gè)根本要素 方式名 用于描畫方式的名字,闡明方式的問(wèn)題、處理方案和效果。 問(wèn)題 闡明在何種場(chǎng)所運(yùn)用方式。要描畫運(yùn)用方式的先決條件和特定設(shè)計(jì)問(wèn)題。 處理方案 描畫設(shè)計(jì)的成分、它們之間的相互關(guān)系、各自的職責(zé)和協(xié)作方式。 效果 描畫方式運(yùn)用的效果,包括對(duì)時(shí)間

30、和空間的衡量,以及對(duì)系統(tǒng)靈敏性、可擴(kuò)展性、可移植性的影響。.設(shè)計(jì)方式的特性靈敏性 設(shè)計(jì)方式應(yīng)是精巧的處理方法。普通化 設(shè)計(jì)方式不依賴于某一種特定的系統(tǒng)類型、程序設(shè)計(jì)言語(yǔ)或運(yùn)用領(lǐng)域。已驗(yàn)證 設(shè)計(jì)方式已在某些面向?qū)ο笙到y(tǒng)中實(shí)際并已經(jīng)過(guò)測(cè)試。簡(jiǎn)單性 設(shè)計(jì)方式通常較小,只需幾個(gè)類。可復(fù)用 可在設(shè)計(jì)層次不是編碼層次運(yùn)用于一切的系統(tǒng)。面向?qū)ο?設(shè)計(jì)方式以面向?qū)ο蟮姆绞匠霈F(xiàn)。.設(shè)計(jì)方式的類型根據(jù)設(shè)計(jì)方式任務(wù)目的不同,方式可分為 創(chuàng)建型方式(Creational pattern) 構(gòu)外型方式(Structural pattern) 行為型方式(Behavioral pattern)創(chuàng)建型方式與對(duì)象的創(chuàng)建有關(guān);

31、構(gòu)外型方式處置類和對(duì)象的組合,將一組對(duì)象組合成一個(gè)大的構(gòu)造,例如復(fù)雜的用戶界面;行為型方式描畫類或?qū)ο蟮慕换ズ吐氊?zé)分配,定義對(duì)象間的通訊和復(fù)雜程序中的流控。.1、創(chuàng)建型方式創(chuàng)建型方式描畫怎樣創(chuàng)建一個(gè)對(duì)象。它隱藏對(duì)象創(chuàng)建的詳細(xì)細(xì)節(jié),運(yùn)用程序可不依賴詳細(xì)的對(duì)象。因此當(dāng)添加一個(gè)新對(duì)象時(shí)幾乎不需求修正代碼。創(chuàng)建型類方式將對(duì)象的部分創(chuàng)建任務(wù)延遲到子類,創(chuàng)建型對(duì)象方式將它延遲到另一對(duì)象中。這時(shí),重點(diǎn)從定義固定的行為集合轉(zhuǎn)向定義一個(gè)較小的根本行為集合,由這些行為可以組成許多更復(fù)雜的行為集合。.方式的特點(diǎn) 封裝了系統(tǒng)中運(yùn)用的類的詳細(xì)信息; 隱藏了這些類的實(shí)例如何創(chuàng)建、如何放在一同的機(jī)制。系統(tǒng)關(guān)于這些對(duì)象所知道

32、的只需由籠統(tǒng)類定義的接口。創(chuàng)建型類方式有Factory Method (工廠方法)。創(chuàng)建型對(duì)象方式包括Abstract Factory (籠統(tǒng)工廠)、Builder (生成器)、Prototype (原型)、Singleton (單件)四種方式。.2、構(gòu)外型方式構(gòu)外型方式處置類或?qū)ο蟮慕M合,即描畫類和對(duì)象之間怎樣組織起來(lái)構(gòu)成大的構(gòu)造,從而實(shí)現(xiàn)新的功能。構(gòu)外型類方式采用承繼機(jī)制來(lái)組合類,如Adapter (適配器)方式;構(gòu)外型對(duì)象方式那么描畫了對(duì)象的組裝方式,如Adapter (適配器)、Bridge (橋接)、Composite (復(fù)合)、Decorator (裝飾)、Facade (外觀)、

33、Flyweight (享元)、Proxy (代理) 等七種方式。.3、行為型方式行為方式涉及算法和對(duì)象之間職責(zé)的分配。行為方式不僅描畫對(duì)象或類的方式,還描畫它們之間的通訊。行為方式刻劃了在運(yùn)轉(zhuǎn)時(shí)難以跟蹤的復(fù)雜的控制流,但這類方式把人們的留意力從控制流轉(zhuǎn)移到對(duì)象間的相互聯(lián)絡(luò)。類行為方式運(yùn)用承繼機(jī)制在類間分派行為,如Template Method (模板方法)和Interpreter (解釋器) 方式。.對(duì)象行為方式運(yùn)用對(duì)象復(fù)合而不是承繼,描畫對(duì)象如何協(xié)同完成預(yù)定義務(wù),如Chain of Responsibility (職責(zé)鏈)、Command (命令)、Iterator (遍歷器)、Mediat

34、or (中介者)、Memento (備忘錄)、Observer (察看者)、State (形狀)、Strategy (戰(zhàn)略)、Visitor (訪問(wèn)者) 等九種方式。.面向?qū)ο鬁y(cè)試 面向?qū)ο笙到y(tǒng)的測(cè)試與傳統(tǒng)的基于功能的系統(tǒng)的測(cè)試之間存在很大差別:對(duì)象作為一個(gè)單獨(dú)的構(gòu)件普通比一個(gè)功能模塊大。由對(duì)象到子系統(tǒng)的集成通常是松散耦合的,沒(méi)有一個(gè)明顯的“頂層。假設(shè)對(duì)象被復(fù)用,測(cè)試者無(wú)權(quán)進(jìn)入構(gòu)件內(nèi)部來(lái)分析其代碼。.面向?qū)ο笙到y(tǒng)的測(cè)試可分為4個(gè)層次:測(cè)試與對(duì)象相關(guān)聯(lián)的單個(gè)操作 它們是一些函數(shù)或程序,傳統(tǒng)的白盒測(cè)試和黑盒測(cè)試方法都可以運(yùn)用。測(cè)試單個(gè)對(duì)象類 黑盒測(cè)試的原理不變,但等價(jià)劃分的概念要擴(kuò)展以適宜操作序列

35、的情況。測(cè)試對(duì)象簇聚集 嚴(yán)厲的自頂向下或自底向上的集成不適宜一組關(guān)聯(lián)對(duì)象的情形。應(yīng)運(yùn)用基于場(chǎng)景的測(cè)試等其他方法。.對(duì)象類測(cè)試測(cè)試面向?qū)ο笙到y(tǒng) 根據(jù)系統(tǒng)需求規(guī)格闡明進(jìn)展檢驗(yàn)和有效性驗(yàn)證的過(guò)程可以像對(duì)其他范型的系一致樣進(jìn)展。在測(cè)試對(duì)象時(shí),完全的覆蓋測(cè)試該當(dāng)包括:隔離對(duì)象中一切操作,進(jìn)展獨(dú)立測(cè)試。測(cè)試對(duì)象中一切屬性的設(shè)置和訪問(wèn)。測(cè)試對(duì)象的一切能夠的形狀轉(zhuǎn)換。一切能夠引起形狀改動(dòng)的事件都要模擬到。.對(duì)象類,作為在語(yǔ)法上獨(dú)立的構(gòu)件,該當(dāng)允許用在不同的運(yùn)用中。每個(gè)類都應(yīng)是可靠的,并且不需了解任何實(shí)現(xiàn)的細(xì)節(jié)就能復(fù)用。因此,對(duì)象類應(yīng)盡能夠孤立地進(jìn)展測(cè)試。設(shè)計(jì)操作的測(cè)試用例時(shí)需求留意:首先定義測(cè)試對(duì)象的各操作的

36、測(cè)試用例。對(duì)于一個(gè)單獨(dú)的操作,可經(jīng)過(guò)該操作的前置條件選擇測(cè)試用例,產(chǎn)生輸出,讓測(cè)試者可以判別后置條件能否可以得到滿足。 .各個(gè)操作的測(cè)試與傳統(tǒng)對(duì)函數(shù)過(guò)程定義的測(cè)試根本一樣。然后再把測(cè)試用例組擴(kuò)展,針對(duì)被測(cè)操作調(diào)用對(duì)象類中其他操作的情況,設(shè)計(jì)操作序列的測(cè)試用例組。測(cè)試可以覆蓋每個(gè)操作的整個(gè)輸入域。但這不夠,還必需測(cè)試這些操作的相互作用,才干以為測(cè)試是充分的。各個(gè)操作間的相互作用包括類內(nèi)通訊和類間通訊。.putReferencePoint(Point)moveTo(Point)ReferencePointarea( )draw( )erase( )getReferencePoint(Point)DisplayableShape(Point)DisplayableShape類內(nèi)音訊類間音訊DisplayableShape( ).在設(shè)計(jì)對(duì)象類的規(guī)格闡明測(cè)試時(shí)需求留意:把對(duì)象類當(dāng)做一個(gè)黑盒,確認(rèn)類的實(shí)現(xiàn)能否遵照它的定義。對(duì)于“Stack的測(cè)試該當(dāng)確保 LIFO 原那么得以實(shí)施。對(duì)于多數(shù)的對(duì)象類,主要檢驗(yàn)在類聲明的 pub

溫馨提示

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

最新文檔

評(píng)論

0/150

提交評(píng)論