UML系統(tǒng)分析與設(shè)計(jì)教程(第2版) 課件 第9-11章 活動圖、狀態(tài)機(jī)圖、組件圖與部署圖_第1頁
UML系統(tǒng)分析與設(shè)計(jì)教程(第2版) 課件 第9-11章 活動圖、狀態(tài)機(jī)圖、組件圖與部署圖_第2頁
UML系統(tǒng)分析與設(shè)計(jì)教程(第2版) 課件 第9-11章 活動圖、狀態(tài)機(jī)圖、組件圖與部署圖_第3頁
UML系統(tǒng)分析與設(shè)計(jì)教程(第2版) 課件 第9-11章 活動圖、狀態(tài)機(jī)圖、組件圖與部署圖_第4頁
UML系統(tǒng)分析與設(shè)計(jì)教程(第2版) 課件 第9-11章 活動圖、狀態(tài)機(jī)圖、組件圖與部署圖_第5頁
已閱讀5頁,還剩42頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

UML系統(tǒng)分析與設(shè)計(jì)SystemAnalysis&Design冀振燕北京交通大學(xué)

第九章活動圖活動圖組成元素活動圖的應(yīng)用UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi2活動圖活動圖主要是一個(gè)流圖,描述了從活動到活動的流?;顒邮窃跔顟B(tài)機(jī)中進(jìn)行的一個(gè)非原子的執(zhí)行,它由一系列的動作組成。動作是由可執(zhí)行的不可分的計(jì)算組成,這些計(jì)算可以引起系統(tǒng)的狀態(tài)發(fā)生變化或者返回一個(gè)值。交互作用圖強(qiáng)調(diào)從對象到對象的控制流。活動圖則強(qiáng)調(diào)從活動到活動的控制流。活動圖主要包含下列元素:●活動狀態(tài) ●動作狀態(tài)●躍遷 ●對象UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi3活動圖活動圖UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi4組成元素動作狀態(tài)在用活動圖描述的控制流中,或者要計(jì)算為屬性賦值的表達(dá)式,或者調(diào)用對象的操作,或者發(fā)送信號給對象,或者創(chuàng)建、破壞對象,所有這些可執(zhí)行的、不可分的計(jì)算都被稱為動作狀態(tài)。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi5組成元素活動狀態(tài)與動作狀態(tài)相反,活動狀態(tài)是非原子的、可以分解的,也就是說活動狀態(tài)是可以被打斷的。通常,活動狀態(tài)需要一段時(shí)間才能完成?;顒訝顟B(tài)和動作狀態(tài)的UML符號沒有區(qū)別,但是活動狀態(tài)可以有入口動作、出口動作(入口動作和出口動作分別是進(jìn)入或離開狀態(tài)時(shí)要執(zhí)行的動作)和對子狀態(tài)機(jī)的規(guī)定。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi6組成元素躍遷當(dāng)狀態(tài)的活動或動作完成時(shí),控制流立即傳遞到下一個(gè)動作或活動狀態(tài)。躍遷被用來表示從一個(gè)動作或活動狀態(tài)傳遞到下一個(gè)動作或活動狀態(tài)的路徑。躍遷的UML符號可以用簡單的有向線表示。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi7組成元素分支在流圖中,還可以含有分支,分支定義了基于布爾表達(dá)式的替換路徑。分支起始于判定。分支有一個(gè)輸入,有兩個(gè)或多個(gè)輸出。在每個(gè)輸出的躍遷上,均有一個(gè)布爾表達(dá)式,只有該表達(dá)式為真時(shí),該輸出躍遷才能發(fā)生。各個(gè)輸出的護(hù)衛(wèi)條件不應(yīng)該重復(fù),否則,控制流是有歧義的;但這些護(hù)衛(wèi)條件應(yīng)該覆蓋所有的可能性,否則,控制流會停滯??梢砸?guī)定一個(gè)輸出躍遷的護(hù)衛(wèi)表達(dá)式為else,如果沒有其他的護(hù)衛(wèi)表達(dá)式為真,控制流則轉(zhuǎn)向該躍遷。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi8分叉和聯(lián)結(jié)在UML中,使用同步條來規(guī)定這些并行控制流的分叉與聯(lián)結(jié)(ForkandJoin)。同步條的UML符號是一條粗的水平線或垂直線。分叉和聯(lián)結(jié)應(yīng)該是平衡的,也就是說,離開分叉的控制流的數(shù)目應(yīng)該與進(jìn)入相應(yīng)聯(lián)結(jié)的控制流數(shù)目相等。并行控制流的活動可以通過發(fā)送信號來彼此通信。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi9組成元素分叉和聯(lián)結(jié)UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi10組成元素泳道活動圖描述了某項(xiàng)活動發(fā)生了什么,但沒有說明由誰來完成。在程序設(shè)計(jì)中,這意味著活動圖沒有描述出各個(gè)活動由哪個(gè)類來完成,泳道(Swimlane)解決了這一問題。泳道的UML符號用矩形框來表示。將對象名放在矩形框的頂部,將屬于某個(gè)對象的活動放在該對象的泳道內(nèi),而泳道中的活動則由相應(yīng)對象負(fù)責(zé)。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi11組成元素對象流與活動圖有關(guān)的控制流可能涉及對象。可以將對象放在活動圖中,并用箭頭將對象和產(chǎn)生、破壞或修改該對象的活動或躍遷連接起來,這被稱作對象流(ObjectFlow),因?yàn)樗砹藢ο笤诳刂屏髦械膮⑴c?;顒訄D除了可以說明對象流,還可以說明對象的角色、狀態(tài)和屬性值的變化。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi12組成元素對象流UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi13活動圖的應(yīng)用通??梢詫⒒顒訄D用于以下兩種情況。(1)為工作流建模。在為工作流建模時(shí),應(yīng)完成如下內(nèi)容。確定工作流的中心。這是因?yàn)閷τ诒容^復(fù)雜的系統(tǒng),用一個(gè)活動圖描述所有重要的工作流是不可能的。選擇與工作流有關(guān)的商業(yè)對象,并為每個(gè)重要的商業(yè)對象創(chuàng)建一個(gè)泳道。識別工作流初始狀態(tài)的前置條件和工作流最終狀態(tài)的后置條件,這有利于確定工作流的邊界。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi14活動圖的應(yīng)用(接上頁)從工作流的初始狀態(tài)開始,確定隨時(shí)間發(fā)生的活動和動作,并將它們作為活動狀態(tài)或動作狀態(tài)放在活動圖中。對于復(fù)雜的動作或多次出現(xiàn)的動作集合,可以將它們合并為活動狀態(tài),再提供一個(gè)單獨(dú)的活動圖來展開活動狀態(tài)。用躍遷連接活動狀態(tài)和動作狀態(tài),并考慮分支、分叉和聯(lián)結(jié)。如果在工作流中涉及重要的對象,則將對象放在圖中,必要時(shí)描述對象屬性值和狀態(tài)的變化。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi15活動圖的應(yīng)用(2)為操作建模。為操作建立模型,應(yīng)完成以下內(nèi)容。收集與操作有關(guān)的抽象,包括操作的參數(shù)、返回類型、操作所在類的屬性等。識別工作流初始狀態(tài)的前置條件和最終狀態(tài)的后置條件,還要識別出在操作執(zhí)行過程中必須持有的類的不變量。從工作流的初始狀態(tài)開始,確定隨時(shí)間發(fā)生的活動和動作,并將它們作為活動狀態(tài)或動作狀態(tài)放在活動圖中。必要時(shí)使用分支、分叉和聯(lián)結(jié)。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi16publicvoidhandleThread(intstate){for(inti=0;i<controls.length;i++){if(state==CustomControlsContext.START){if(controls[i]instanceof

CustomControls){((CustomControls)controls[i]).start();}}elseif(state==CustomControlsContext.STOP){if(controls[i]instanceof

CustomControls){((CustomControls)controls[i]).stop();}}}}UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi下面是一段Java源代碼,是方法handleThread(intstate)的源代碼,下頁圖示的活動圖則描述了該方法的流程。17活動圖UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi18小結(jié)在UML中,活動圖是為系統(tǒng)的動態(tài)方面建模的7個(gè)圖之一?;顒訄D主要是一個(gè)流圖,它描述了從活動到活動的控制流,它還可以用來描述對象在控制流的不同點(diǎn)從一個(gè)狀態(tài)轉(zhuǎn)移到另一個(gè)狀態(tài)時(shí)的對象流。本章介紹了活動圖的語義和功能,并對活動圖的組成部分,包括動作狀態(tài)、活動狀態(tài)、躍遷、分支、分叉和聯(lián)結(jié)、泳道、對象流逐一進(jìn)行了講解,舉例說明如何使用活動圖為工作流建模和為操作建模。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi19UML系統(tǒng)分析與設(shè)計(jì)SystemAnalysis&Design冀振燕北京交通大學(xué)

第十章狀態(tài)機(jī)圖狀態(tài)機(jī)圖狀態(tài)機(jī)圖的應(yīng)用UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi21狀態(tài)機(jī)圖狀態(tài)機(jī)圖(StateMachineDiagrams)給出了一個(gè)狀態(tài)機(jī),強(qiáng)調(diào)了從狀態(tài)到狀態(tài)的控制流。狀態(tài)機(jī)(StateMachine)定義了對象在生命周期中響應(yīng)事件所經(jīng)歷的狀態(tài)的序列以及對象對這些事件的響應(yīng)。狀態(tài)機(jī)由狀態(tài)、躍遷、事件、活動、動作等組成。狀態(tài)(State)代表對象在生命周期中的一種條件或狀況,在這種狀況下,對象滿足某個(gè)條件,或執(zhí)行某個(gè)動作、或等待某個(gè)事件。一個(gè)狀態(tài)在一個(gè)有限的時(shí)間段內(nèi)存在。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi22狀態(tài)機(jī)圖事件(Event)是一個(gè)重要事件的規(guī)范,該事件在時(shí)間和空間域中有一個(gè)位置。躍遷(Transition)是兩個(gè)狀態(tài)之間的關(guān)系,它表示第一個(gè)狀態(tài)的對象將執(zhí)行某個(gè)動作,如果規(guī)定的事件發(fā)生或規(guī)定的條件被滿足,則對象進(jìn)入第二個(gè)狀態(tài)?;顒樱ˋctivity)是狀態(tài)機(jī)中正在執(zhí)行的可分解的計(jì)算。動作(Action)是可執(zhí)行的、不可分的計(jì)算,該計(jì)算造成了模型的狀態(tài)變化或者值的返回。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi23狀態(tài)機(jī)圖狀態(tài)機(jī)圖UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi24狀態(tài)機(jī)圖的應(yīng)用交互作用圖描述了多個(gè)對象間的交互作用,而狀態(tài)機(jī)圖描述單個(gè)對象在它的整個(gè)生命周期的行為?;顒訄D描述了從活動到活動的控制流,狀態(tài)機(jī)圖描述了從事件到事件的控制流。狀態(tài)機(jī)圖可以用來描述整個(gè)系統(tǒng)、子系統(tǒng)、或類的動態(tài)方面,還可以描述用例的一個(gè)腳本。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi25狀態(tài)機(jī)圖的應(yīng)用為一個(gè)事件驅(qū)動對象建模,應(yīng)完成如下內(nèi)容。確定狀態(tài)機(jī)的上下文。狀態(tài)機(jī)的上下文可以是類、用例、子系統(tǒng)或系統(tǒng)整體。確定初始狀態(tài)和最終狀態(tài)。通過考慮對象能夠存在一段時(shí)間的條件,確定對象的穩(wěn)定狀態(tài)。確定穩(wěn)定狀態(tài)在對象生命周期中的局部排序。確定觸發(fā)從狀態(tài)到狀態(tài)躍遷的事件。確定狀態(tài)變化的動作??紤]使用子狀態(tài)、分支、歷史狀態(tài)等來簡化狀態(tài)機(jī)圖。確定是否所有的狀態(tài)都在事件的某個(gè)組合中可達(dá)。確定沒有狀態(tài)是死狀態(tài)。死狀態(tài)是指沒有事件或事件組合可以使對象從這個(gè)狀態(tài)中躍出。檢查狀態(tài)機(jī)是否違反所期望的事件順序和響應(yīng)。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi26電梯系統(tǒng)的狀態(tài)機(jī)圖UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi27…intsum=0;…publicintregister(Students){switch(state){caseOpen:if(sum<40){ state=Open; sum=sum+1; }elsestate=Close;break; caseClose: System.out.println(“theclassisfull”); } returnsum;}UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi28下面是一段Java源代碼和對應(yīng)的狀態(tài)機(jī)圖小結(jié)狀態(tài)機(jī)圖描述了一個(gè)特定對象的所有可能狀態(tài),以及引起狀態(tài)躍遷的事件。狀態(tài)機(jī)圖用來模擬系統(tǒng)的動態(tài)方面,這些動態(tài)方面指系統(tǒng)對象按事件發(fā)生順序排序的行為。狀態(tài)機(jī)圖可以用來描述整個(gè)系統(tǒng)、子系統(tǒng)或類的動態(tài)方面,還可以用來描述用例的一個(gè)腳本。本章介紹了狀態(tài)機(jī)圖的語義和功能,并舉例說明了如何應(yīng)用狀態(tài)機(jī)圖為事件驅(qū)動的對象建模。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi29UML系統(tǒng)分析與設(shè)計(jì)SystemAnalysis&Design冀振燕北京交通大學(xué)

第十一章組件圖與部署圖組件圖組件圖的應(yīng)用部署圖部署圖的應(yīng)用UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi31組件圖組件圖(ComponentDiagram)描述了組件及組件間的關(guān)系,表示了組件之間的組織和依賴關(guān)系。組件圖是用來為面向?qū)ο笙到y(tǒng)的物理實(shí)現(xiàn)建模的兩種圖之一。組件圖包含下列元素:組件。接口。依賴關(guān)系、類屬關(guān)系、關(guān)聯(lián)關(guān)系和實(shí)現(xiàn)關(guān)系。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi32組件圖組件圖UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi33組件圖的應(yīng)用組件圖為系統(tǒng)的實(shí)現(xiàn)視建模,通常可以用在下述4種情況。1.為源代碼建模用組件圖為源代碼建模時(shí),應(yīng)注意以下內(nèi)容:將源代碼文件表示為文件的組件衍型。對于大系統(tǒng),用包將源代碼文件分組??紤]使用標(biāo)記值來描述源代碼文件的一些信息,例如,源代碼文件的版本號、作者、修改日期等。使用依賴關(guān)系來描述這些文件之間的編譯依賴關(guān)系。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi34組件圖的應(yīng)用2.為可執(zhí)行版本建模可以用組件圖來描述構(gòu)成軟件系統(tǒng)的組件以及組件間的關(guān)系。在為一個(gè)可執(zhí)行版本建模時(shí),應(yīng)注意以下內(nèi)容。確定系統(tǒng)的組件集。考慮組件集中每個(gè)組件的衍型??紤]組件集中組件之間的關(guān)系。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi35組件圖的應(yīng)用3.為數(shù)據(jù)庫建模在為物理數(shù)據(jù)庫建模時(shí)應(yīng)注意以下內(nèi)容。識別出模型中代表邏輯數(shù)據(jù)庫模式的類。確定將這些類映射到表的策略。確定過程需要考慮數(shù)據(jù)庫的物理分布。創(chuàng)建含有table組件的組件圖,為映射進(jìn)行可視化建模。如果可能,使用工具的幫助將邏輯設(shè)計(jì)轉(zhuǎn)化為物理設(shè)計(jì)。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi36組件圖的應(yīng)用為數(shù)據(jù)庫建模的組件圖UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi37組件圖的應(yīng)用4.為自適應(yīng)系統(tǒng)建模在為自適應(yīng)系統(tǒng)建模時(shí),應(yīng)注意以下內(nèi)容。需要考慮從一個(gè)節(jié)點(diǎn)遷移到另一個(gè)節(jié)點(diǎn)的組件的物理分布??梢酝ㄟ^在組件圖中使用位置標(biāo)記值來標(biāo)出組件實(shí)例的位置。如果需要描述引起組件遷移的活動,則需要創(chuàng)建含有組件實(shí)例的相應(yīng)交互作用圖。具有不同位置標(biāo)記值的同一個(gè)組件實(shí)例可以在圖中出現(xiàn)多次,以表示組件實(shí)例的位置變化。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi38部署圖部署圖(DeploymentDiagram)描述了節(jié)點(diǎn)和運(yùn)行其上的組件的配置。部署圖描述了運(yùn)行系統(tǒng)的硬件拓?fù)?,它為系統(tǒng)中物理節(jié)點(diǎn)、節(jié)點(diǎn)之間關(guān)系的靜態(tài)方面建立了可視化的模型,并規(guī)定了構(gòu)造的細(xì)節(jié)。部署圖含有:節(jié)點(diǎn)。依賴、關(guān)聯(lián)關(guān)系。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi39部署圖課程表制定系統(tǒng)部署圖UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi40部署圖的應(yīng)用部署圖通常用來描述下列3種系統(tǒng)的靜態(tài)部署視。1.為嵌入式系統(tǒng)建模部署圖可用來為構(gòu)成嵌入式系統(tǒng)的設(shè)備和處理器建模。為嵌入式系統(tǒng)建模,應(yīng)注意以下內(nèi)容。確定嵌入式系統(tǒng)的節(jié)點(diǎn)。使用UML的擴(kuò)充機(jī)制定義特定于系統(tǒng)的衍型(甚至使用特定圖標(biāo)),為不常見的設(shè)備提供可視化的表示。在部署圖中,規(guī)定處理器和設(shè)備之間的關(guān)系。如果必要,為智能化的設(shè)備提供更詳細(xì)的部署圖。UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi41自動加油站系統(tǒng)部署圖UML系統(tǒng)分析與設(shè)計(jì)第2版ZhenyanJi42部署圖的應(yīng)用2.為客戶/服務(wù)器系統(tǒng)建??蛻?服務(wù)器系統(tǒng)是分布式系統(tǒng)的一種,這種系統(tǒng)需要考慮客戶端和服務(wù)器端的網(wǎng)絡(luò)連接以及系統(tǒng)的軟件組件在節(jié)點(diǎn)上的物理分布,可以用部署圖來描述這種系統(tǒng)的拓?fù)洹榭蛻?服務(wù)器系統(tǒng)建模時(shí),要注意以下內(nèi)容。確定代表系統(tǒng)的客戶端處理器、服務(wù)器端處理

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論