日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
術(shù)語匯編解析UML動態(tài)建模機制

本文和大家重點討論一下UML動態(tài)建模機制的概念,UML動態(tài)建模語言以靜態(tài)建模機制為基礎(chǔ),用例間存在兩種關(guān)系:當(dāng)一個用例與另一個用例相似,但所做的動作多一些,就可以用到擴展關(guān)系;當(dāng)有一大塊相似的動作存在于幾個用例,又不想重復(fù)描述該動作時,就可以用到使用關(guān)系。

站在用戶的角度思考問題,與客戶深入溝通,找到海拉爾網(wǎng)站設(shè)計與海拉爾網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站設(shè)計、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、域名注冊、網(wǎng)絡(luò)空間、企業(yè)郵箱。業(yè)務(wù)覆蓋海拉爾地區(qū)。

UML動態(tài)建模機制

推薦UML動態(tài)建模語言以靜態(tài)建模機制為基礎(chǔ),UML的靜態(tài)建模機制包括:用例圖、類圖、對象圖、包、構(gòu)件圖和配置圖。用例間存在兩種關(guān)系:當(dāng)一個用例與另一個用例相似,但所做的動作多一些,就可以用到擴展關(guān)系;當(dāng)有一大塊相似的動作存在于幾個用例,又不想重復(fù)描述該動作時,就可以用到使用關(guān)系。

類關(guān)聯(lián)存在兩種形式:

1)聚集表示類之間的關(guān)系是整體與部分的關(guān)系,一輛轎車包含四個車輪、一個方向盤、一個發(fā)動機和一個底盤,這是聚集的一個例子,聚集可以進一步劃分成共享聚集(SharedAggregation)和組成,例如,課題組包含許多成員,但是每個成員又可以是另一個課題組的成員,即部分可以參加多個整體,我們稱之為共享聚集;

2)另一種情況是整體擁有各部分,部分與整體共存,如整體不存在了,部分也會隨之消失,這稱為組成(Composition),例如,我們打開一個視窗口,它就由標(biāo)題、外框和顯示區(qū)所組成。一旦消亡則各部分同時消失。下面詳細(xì)介紹一下動態(tài)建模的關(guān)系要素。

     
       1.消息

  在面向?qū)ο蠹夹g(shù)中,對象間的交互是通過對象間消息的傳遞來完成的。在UML的四個動態(tài)模型中均用到消息這個概念。通常,當(dāng)一個對象調(diào)用另一個對象中的操作時,即完成了一次消息傳遞。當(dāng)操作執(zhí)行后,控制便返回到調(diào)用者。對象通過相互間的通信(消息傳遞)進行合作,并在其生命周期中根據(jù)通信的結(jié)果不斷改變自身的狀態(tài)。

  在UML中,消息的圖形表示是用帶有箭頭的線段將消息的發(fā)送者和接收者聯(lián)系起來,箭頭的類型表示消息的類型,如圖2所示。

  
  UML定義的消息類型有三種:

  簡單消息(SimpleMessage)表示簡單的控制流。用于描述控制如何在對象間進行傳遞,而不考慮通信的細(xì)節(jié)。

  同步消息(SynchronousMessage)表示嵌套的控制流。操作的調(diào)用是一種典型的同步消息。調(diào)用者發(fā)出消息后必須等待消息返回,只有當(dāng)處理消息的操作執(zhí)行完畢后,調(diào)用者才可繼續(xù)執(zhí)行自己的操作。

  異步消息(AsynchronousMessage)表示異步控制流。當(dāng)調(diào)用者發(fā)出消息后不用等待消息的返回即可繼續(xù)執(zhí)行自己的操作。異步消息主要用于描述實時系統(tǒng)中的并發(fā)行為。

  2.狀態(tài)圖

  狀態(tài)圖(StateDiagram)用來描述一個特定對象的所有可能狀態(tài)及其引起狀態(tài)轉(zhuǎn)移的事件。大多數(shù)面向?qū)ο蠹夹g(shù)都用狀態(tài)圖表示單個對象在其生命周期中的行為。一個狀態(tài)圖包括一系列的狀態(tài)以及狀態(tài)之間的轉(zhuǎn)移。

  (1)狀態(tài) 

所有對象都具有狀態(tài),狀態(tài)是對象執(zhí)行了一系列活動的結(jié)果。當(dāng)某個事件發(fā)生后,對象的狀態(tài)將發(fā)生變化。狀態(tài)圖中定義的狀態(tài)有:初態(tài)、終態(tài)、中間狀態(tài)、復(fù)合狀態(tài)。其中,初態(tài)是狀態(tài)圖的起始點,而終態(tài)則是狀態(tài)圖的終點。一個狀態(tài)圖只能有一個初態(tài),而終態(tài)則可以有多個。

 中間狀態(tài)包括兩個區(qū)域:名字域和內(nèi)部轉(zhuǎn)移域,如圖3所示。圖中內(nèi)部轉(zhuǎn)移域是可選的,其中所列的動作將在對象處于該狀態(tài)時執(zhí)行,且該動作的執(zhí)行并不改變對象的狀態(tài)。

  一個狀態(tài)可以進一步地細(xì)化為多個子狀態(tài),我們將可以進一步細(xì)化的狀態(tài)稱作復(fù)合狀態(tài)。子狀態(tài)之間有"或關(guān)系"和"與關(guān)系"兩種關(guān)系。或關(guān)系(如圖4)說明在某一時刻僅可到達一個子狀態(tài)。例如,一個處于行駛狀態(tài)的汽車,在"行駛"這個復(fù)合狀態(tài)中有向前和向后兩個不同的子狀態(tài),在某一時刻汽車要么向前,要么向后。與關(guān)系(如圖5)說明復(fù)合狀態(tài)中在某一時刻可同時到達多個子狀態(tài)(稱為并發(fā)子狀態(tài))。具有并發(fā)子狀態(tài)的狀態(tài)圖稱為并發(fā)狀態(tài)圖。

  (2)轉(zhuǎn)移 

狀態(tài)圖中狀態(tài)之間帶箭頭的連線被稱為轉(zhuǎn)移。狀態(tài)的變遷通常是由事件觸發(fā)的,此時應(yīng)在轉(zhuǎn)移上標(biāo)出觸發(fā)轉(zhuǎn)移的事件表達式。如果轉(zhuǎn)移上未標(biāo)明事件,則表示在源狀態(tài)的內(nèi)部活動執(zhí)行完畢后自動觸發(fā)轉(zhuǎn)移。#p#

  3.順序圖

  順序圖(SequenceDiagram)用來描述對象之間動態(tài)的交互關(guān)系,著重體現(xiàn)對象間消息傳遞的時間順序。順序圖存在兩個軸:水平軸表示不同的對象,垂直軸表示時間。順序圖中的對象用一個帶有垂直虛線的矩形框表示,并標(biāo)有對象名和類名。垂直虛線是對象的生命線,用于表示在某段時間內(nèi)對象是存在的。對象間的通信通過在對象的生命線間畫消息來表示。消息的箭頭指明消息的類型。

順序圖中的消息可以是信號(Signal)、操作調(diào)用或類似于C++中的RPC(RemoteProcedureCalls)和Java中的RMI(RemoteMethodInvocation)。當(dāng)收到消息時,接收對象立即開始執(zhí)行活動,即對象被激活了。通過在對象生命線上顯示一個細(xì)長矩形框來表示激活。

  消息可以用消息名及參數(shù)來標(biāo)識。消息也可帶有順序號,但較少使用。消息還可帶有條件表達式,表示分支或決定是否發(fā)送消息。如果用于表示分支,則每個分支是相互排斥的,即在某一時刻僅可發(fā)送分支中的一個消息。

  在順序圖的左邊可以有說明信息,用于說明消息發(fā)送的時刻、描述動作的執(zhí)行情況以及約束信息等。一個典型的例子就是用于說明一個消息是重復(fù)發(fā)送的。另外,可以定義兩個消息間的時間限制。

  一個對象可以通過發(fā)送消息來創(chuàng)建另一個對象,當(dāng)一個對象被刪除或自我刪除時,該對象用"X"標(biāo)識。

  另外,在很多算法中,遞歸是一種很重要的技術(shù)。當(dāng)一個操作直接或間接調(diào)用自身時,即發(fā)生了遞歸。產(chǎn)生遞歸的消息總是同步消息,返回消息應(yīng)是一個簡單消息。

  4.合作圖

  合作圖(CollaborationDiagram)用于描述相互合作的對象間的交互關(guān)系和鏈接關(guān)系。雖然順序圖和合作圖都用來描述對象間的交互關(guān)系,但側(cè)重點不一樣。順序圖著重體現(xiàn)交互的時間順序,合作圖則著重體現(xiàn)交互對象間的靜態(tài)鏈接關(guān)系。

  合作圖中對象的外觀與順序圖中的一樣。如果一個對象在消息的交互中被創(chuàng)建,則可在對象名稱之后標(biāo)以{new}。類似地,如果一個對象在交互期間被刪除,則可在對象名稱之后標(biāo)以{destroy}。對象間的鏈接關(guān)系類似于類圖中的聯(lián)系(但無多重性標(biāo)志)。通過在對象間的鏈接上標(biāo)志帶有消息串的消息(簡單、異步或同步消息)來表達對象間的消息傳遞。

 (1)鏈接 鏈接用于表示對象間的各種關(guān)系,包括組成關(guān)系的鏈接(CompositionLink)、聚集關(guān)系的鏈接(AggregationLink)、限定關(guān)系的鏈接(QualifiedLink)以及導(dǎo)航鏈接(NavigationLink)。各種鏈接關(guān)系與類圖中的定義相同,在鏈接的端點位置可以顯示對象的角色名和模板信息。

 (2)消息流 在合作圖的鏈接線上,可以用帶有消息串的消息來描述對象間的交互。消息的箭頭指明消息的流動方向。消息串說明要發(fā)送的消息、消息的參數(shù)、消息的返回值以及消息的序列號等信息。#p#

  5.活動圖(ActivityDiagram)

  活動圖的應(yīng)用非常廣泛,它既可用來描述操作(類的方法)的行為,也可以描述用例和對象內(nèi)部的工作過程?;顒訄D是由狀態(tài)圖變化而來的,它們各自用于不同的目的?;顒訄D依據(jù)對象狀態(tài)的變化來捕獲動作(將要執(zhí)行的工作或活動)與動作的結(jié)果?;顒訄D中一個活動結(jié)束后將立即進入下一個活動(在狀態(tài)圖中狀態(tài)的變遷可能需要事件的觸發(fā))。圖1給出了一個活動圖的例子。
  

  活動和轉(zhuǎn)移

  一項操作可以描述為一系列相關(guān)的活動。活動僅有一個起始點,但可以有多個結(jié)束點?;顒娱g的轉(zhuǎn)移允許帶有g(shù)uard-condition、send-clause和action-expression,其語法與狀態(tài)圖中定義的相同。一個活動可以順序地跟在另一個活動之后,這是簡單的順序關(guān)系。如果在活動圖中使用一個菱形的判斷標(biāo)志,則可以表達條件關(guān)系(見圖1),判斷標(biāo)志可以有多個輸入和輸出轉(zhuǎn)移,但在活動的運作中僅觸發(fā)其中的一個輸出轉(zhuǎn)移。

  活動圖對表示并發(fā)行為也很有用。在活動圖中,使用一個稱為同步條的水平粗線可以將一條轉(zhuǎn)移分為多個并發(fā)執(zhí)行的分支,或?qū)⒍鄠€轉(zhuǎn)移合為一條轉(zhuǎn)移。此時,只有輸入的轉(zhuǎn)移全部有效,同步條才會觸發(fā)轉(zhuǎn)移,進而執(zhí)行后面的活動,如圖2所示。
 

  泳道

  活動圖告訴你發(fā)生了什么,但沒有告訴你該項活動由誰來完成。在程序設(shè)計中,這意味著活動圖沒有描述出各個活動由哪個類來完成。泳道解決了這一問題。它將活動圖的邏輯描述與順序圖、合作圖的責(zé)任描述結(jié)合起來。如圖2所示,泳道用矩形框來表示,屬于某個泳道的活動放在該矩形框內(nèi),將對象名放在矩形框的頂部,表示泳道中的活動由該對象負(fù)責(zé)。

  對象

  在活動圖中可以出現(xiàn)對象。對象可以作為活動的輸入或輸出,對象與活動間的輸入/輸出關(guān)系由虛線箭頭來表示。如果僅表示對象受到某一活動的影響,則可用不帶箭頭的虛線來連接對象與活動,如圖2所示。

  信號

  如圖3所示,在活動圖中可以表示信號的發(fā)送與接收,分別用發(fā)送和接收標(biāo)志來表示。發(fā)送和接收標(biāo)志也可與對象相連,用于表示消息的發(fā)送者和接收者。

  6.四種圖的運用

  上面對UML中用于描述系統(tǒng)動態(tài)行為的四個圖(狀態(tài)圖、順序圖、合作圖和活動圖)做了簡單地介紹。這四個圖均可用于系統(tǒng)的動態(tài)建模,但它們各自的側(cè)重點不同,分別用于不同的目的。下面對如何正確使用這幾個圖做一簡單的總結(jié),在實際的建模過程中要根據(jù)具體情況靈活運用這些建議。

  首先,不要對系統(tǒng)中的每個類都畫狀態(tài)圖。盡管這樣做很***,但太浪費精力,其實你可能只關(guān)心某些類的行為。正確的做法是:為幫助理解類而畫它的狀態(tài)圖。狀態(tài)圖描述跨越多個用例的單個對象的行為,而不適合描述多個對象間的行為合作。為此,常將狀態(tài)圖與其它技術(shù)(如順序圖、合作圖和活動圖)組合使用。

順序圖和合作圖適合描述單個用例中幾個對象的行為。其中順序圖突出對象間交互的順序,而合作圖的布局方法能更清楚地表示出對象之間靜態(tài)的連接關(guān)系。當(dāng)行為較為簡單時,順序圖和合作圖是***的選擇。但當(dāng)行為比變復(fù)雜時,這兩個圖將失去其清晰度。因此,如果想顯示跨越多用例或多線程的復(fù)雜行為,可考慮使用活動圖。另外,順序圖和合作圖僅適合描述對象之間的合作關(guān)系,而不適合對行為進行精確定義,如果想描述跨越多個用例的單個對象的行為,應(yīng)當(dāng)使用狀態(tài)圖。

【編輯推薦】

  1. UML動態(tài)建模機制中合作圖和活動圖用法解析
  2. UML動態(tài)建模機制詳解
  3. UML動態(tài)建模機制專家解析
  4. 五大UML建模工具免費體驗
  5. 名師講解UML動態(tài)建模機制中消息,狀態(tài)圖和順序圖用法

 


本文名稱:術(shù)語匯編解析UML動態(tài)建模機制
文章鏈接:http://www.dlmjj.cn/article/djihiho.html