溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

UML組件圖有什么目的

發(fā)布時(shí)間:2021-12-06 13:52:33 來(lái)源:億速云 閱讀:206 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要為大家展示了“UML組件圖有什么目的”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“UML組件圖有什么目的”這篇文章吧。

1.UML組件圖的目的

UML組件圖的主要目的是顯示系統(tǒng)組件間的結(jié)構(gòu)關(guān)系。在 UML 1.1 中,一個(gè)組件表現(xiàn)了實(shí)施項(xiàng)目,如文件和可運(yùn)行的程序。不幸地,這與組件這個(gè)術(shù)語(yǔ)更為普遍的用法、指象COM組件這樣的東西相沖突。隨著時(shí)間的推移及UML的連續(xù)版本發(fā)布, UML 組件已經(jīng)失去了最初的絕大部分含義。UML 2 正式改變了組件概念的本質(zhì)意思;在 UML 2 中,組件被認(rèn)為是獨(dú)立的,在一個(gè)系統(tǒng)或子系統(tǒng)中的封裝單位,提供一個(gè)或多個(gè)接口。雖然 UML 2 規(guī)范沒(méi)有嚴(yán)格地聲明它,但是組件是呈現(xiàn)事物的更大的設(shè)計(jì)單元,這些事物一般將使用可更換的組件來(lái)實(shí)現(xiàn)。但是,并不象在 UML 1. x中,現(xiàn)在,組件必須有嚴(yán)格的邏輯,設(shè)計(jì)時(shí)構(gòu)造。主要思想是,你能容易地在你的設(shè)計(jì)中重用及/或替換一個(gè)不同的組件實(shí)現(xiàn),因?yàn)橐粋€(gè)組件封裝了行為,實(shí)現(xiàn)了特定接口。1

在以組件為基礎(chǔ)的開(kāi)發(fā)(CBD)中,UML組件圖為架構(gòu)師提供一個(gè)開(kāi)始為解決方案建模的自然形式。UML組件圖允許一個(gè)架構(gòu)師驗(yàn)證系統(tǒng)的必需功能是由組件實(shí)現(xiàn)的,這樣確保了最終系統(tǒng)將會(huì)被接受。
除此之外,UML組件圖對(duì)于不同的小組是有用的交流工具。圖可以呈現(xiàn)給關(guān)鍵項(xiàng)目發(fā)起人及實(shí)現(xiàn)人員。通常,當(dāng)UML組件圖將系統(tǒng)的實(shí)現(xiàn)人員連接起來(lái)的時(shí)候,UML組件圖通??梢允鬼?xiàng)目發(fā)起人感到輕松,因?yàn)閳D展示了對(duì)將要被建立的整個(gè)系統(tǒng)的早期理解。

開(kāi)發(fā)者發(fā)現(xiàn)UML組件圖是有用的,因?yàn)閁ML組件圖給他們提供了將要建立的系統(tǒng)的高層次的架構(gòu)視圖,這將幫助開(kāi)發(fā)者開(kāi)始建立實(shí)現(xiàn)的路標(biāo),并決定關(guān)于任務(wù)分配及(或)增進(jìn)需求技能。系統(tǒng)管理員發(fā)現(xiàn)UML組件圖是有用的,因?yàn)樗麄兛梢垣@得將運(yùn)行于他們系統(tǒng)上的邏輯軟件組件的早期視圖。雖然系統(tǒng)管理員將無(wú)法從圖上確定物理設(shè)備或物理的可執(zhí)行程序,但是,他們?nèi)匀粴g迎UML組件圖,因?yàn)樗^早地提供了關(guān)于組件及其關(guān)系的信息(這允許系統(tǒng)管理員輕松地計(jì)劃后面的工作)。

2.符號(hào)

在現(xiàn)在,UML組件圖符號(hào)集使它成為最容易畫(huà)的 UML 圖之一。圖 1 顯示了一個(gè)使用前 UML 1.4 符號(hào)的簡(jiǎn)單的UML組件圖;這個(gè)例子顯示兩個(gè)組件之間的關(guān)系:一個(gè)使用了Inventory System組件的Order System組件。正如你所能見(jiàn)到的,在UML 1.4 中,用一個(gè)大方塊,并且在它的左邊有兩個(gè)凸出的小方塊,來(lái)表示組件。

UML組件圖有什么目的

圖 1:這個(gè)簡(jiǎn)單的UML組件圖使用 UML 1.4 符號(hào)顯示Order System的一般性依賴關(guān)系

上述的 UML 1.4 符號(hào)在 UML 2 中仍然被支持。然而,UML 1.4 符號(hào)集在較大的系統(tǒng)中不能很好地調(diào)節(jié)。關(guān)于這一點(diǎn)的理由是,如同我們?cè)谶@篇文章的其余部分將會(huì)見(jiàn)到一樣,UML 2 顯著地增強(qiáng)了UML組件圖的符號(hào)集。在維持它易于理解的條件下,UML 2 符號(hào)能夠調(diào)節(jié)得更好,并且符號(hào)集也具有更多的信息。

讓我們依照 UML 2 規(guī)范一步步建立UML組件圖。

3.基礎(chǔ)

現(xiàn)在,在 UML 2 中畫(huà)一個(gè)組件很類似于在一個(gè)類圖上畫(huà)一個(gè)類。事實(shí)上,在 UML 2 中,一個(gè)組件僅僅是類概念的一個(gè)特殊版本。這意味著適用于類分類器的符號(hào)規(guī)則也適用于組件分類器。(如果你已經(jīng)讀了并理解了我以前的關(guān)于大體上的結(jié)構(gòu)圖和類圖細(xì)節(jié)的文章 [http:// www. ibm.com/developerworks/cn/rational/rationaledge/content/feb05/bell/index.shtml],你就會(huì)很易理解UML組件圖)。

在 UML 2 中,一個(gè)組件被畫(huà)成堆積著可選擇小塊的一個(gè)立著的長(zhǎng)方形。UML 2 中,組件的一個(gè)高層次的抽象視圖,可以用一個(gè)長(zhǎng)方形建模,包括組件的名字和組件原型的文字和/或圖標(biāo)。組件原型的文本是“«component»”,而組件原型圖標(biāo)是在左邊有兩個(gè)凸出的小長(zhǎng)方形的一個(gè)大長(zhǎng)方形(UML 1.4 中組件的符號(hào)元素)。圖 2 顯示,組件可以用UML 2規(guī)范中的三種不同方法表示。

UML組件圖有什么目的

圖 2:畫(huà)組件名字區(qū)的不同方法

當(dāng)在圖上畫(huà)一個(gè)組件時(shí),重要的是,你總要包括組件原型文本(在雙重尖括號(hào)中的那個(gè)component,如圖 2 所示)和/或圖標(biāo)。理由呢?在 UML 中,沒(méi)有任何原型分類器的一個(gè)長(zhǎng)方形被解釋為一個(gè)類組件。組件原型和/或圖標(biāo)用來(lái)區(qū)別作為組件元素的長(zhǎng)方形。

4.為組件提供/要求接口建模

在圖 2 中所畫(huà)的Order組件表現(xiàn)了所有有效的符號(hào)元素;然而,一個(gè)典型的UML組件圖包括更多的信息。一個(gè)組件元素可以在名字區(qū)下面附加額外的區(qū)。如前面所提到的,一個(gè)組件是提供一個(gè)或更多公共接口的獨(dú)立單元。提供的接口代表了組件提供給它的用戶/客戶的服務(wù)的正式契約。圖 3 顯示了Order組件有第二個(gè)區(qū),用來(lái)表示Order組件提供和要求的接口。UML組件圖有什么目的


圖 3:這里額外的區(qū)顯示Order組件提供和要求的接口。

在圖 3 中的Order組件例子中,組件提供了名為 OrderEntry 和 AccountPayable 的接口。此外,組件也要求另外一個(gè)組件提供Person接口。3

5.UML組件圖中組件接口建模的其它方法

UML 2 也引入另外一種方法來(lái)顯示組件提供并要求的接口。這個(gè)方法是建立一個(gè)里面有組件名的大長(zhǎng)方形,并在長(zhǎng)方形的外面放置在 UML 2 規(guī)范中稱為接口符號(hào)的東西。這第二種方法在圖 4 中舉例說(shuō)明。

UML組件圖有什么目的

圖 4: 一種可選擇的方法(與圖3相比):使用接口符號(hào)顯示組件提供/要求的接口

在這第二種方法中,在末端有一個(gè)完整的圓周的接口符號(hào)代表組件提供的接口 -- “棒棒糖”是這個(gè)接口分類器實(shí)現(xiàn)關(guān)系符號(hào)的速記法。在末端只有半個(gè)圓的接口(又稱插座)符號(hào)代表組件要求的接口(在兩種情況下,接口的名字被放置在接口符號(hào)本身的附近)。即使圖 4 看起來(lái)與圖 3 有很大的不同,但兩個(gè)圖都提供了相同的信息 -- 例如,Order組件提供兩個(gè)接口:OrderEntry 和 AccountPayable,而且Order組件 要求 Person接口。

以上是“UML組件圖有什么目的”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

uml
AI