為了了解UML,我們開篇先大致了解一些UML的概念。
我覺得這些概念看了之后大致有個(gè)印象就好了。
因?yàn)椴辉趯?shí)際的過程中使用,沒有講到具體的圖的時(shí)候,很難理解。
特別是對(duì)象之間的關(guān)系,以及各種圖的分類和名稱。
但是,這個(gè)部分又不能不講。
UML發(fā)展至今其實(shí)是融合了很多大神的經(jīng)驗(yàn)及智慧。
其初衷其實(shí)是為了發(fā)展出一套讓全世界從業(yè)人員都可以看懂的建模語(yǔ)言。
類似于軟件界的五線譜。
你即便不懂英語(yǔ)、日語(yǔ)、德語(yǔ)等等,你看一張UML圖,也能大致理解表達(dá)的意思,并且不用別人過多解釋。
所以我覺得如果你是要畫UML圖就要遵循UML的規(guī)范,而不是自創(chuàng)。
否則別人就會(huì)看不懂了。
然鵝,讓我一直很困惑的是,各個(gè)大廠的UML建模軟件卻完全各搞各的,沒有嚴(yán)格遵循規(guī)范。
可能也是因?yàn)閁ML本身也在不斷發(fā)展的緣故吧。
盡管如此,我還是建議大家盡量用規(guī)范的表達(dá)方法,這樣不容易產(chǎn)生歧義。
如果要用工具,那么至少在一個(gè)項(xiàng)目或者在公司內(nèi)部保持統(tǒng)一,并且給出圖例規(guī)范說明。
防止大家有理解不一致的地方,如果造成更多的困擾,那么就有違UML的初衷了。
什么是UML
具體的發(fā)展史大家可以自行度娘,或者去OMG的官網(wǎng)查看詳細(xì)信息。
在這里,我想特別標(biāo)注幾點(diǎn)我覺得很重要的信息:
UML起源于多種面向?qū)ο蠼7椒?,由OMG開發(fā),目前已經(jīng)成為工業(yè)標(biāo)準(zhǔn)。
UML自1997年發(fā)布1.1版本以來,經(jīng)歷10年后,已經(jīng)發(fā)展到了2.5版本了。
UML的意義在于:
- 在發(fā)展的過程中,統(tǒng)一了Booch、OMT和OOSE等方法中的基本概念和符號(hào)。
- UML吸取了面向?qū)ο箢I(lǐng)域中各種優(yōu)秀思想,是開發(fā)者們根據(jù)最優(yōu)秀的OO方法和豐富的計(jì)算機(jī)科學(xué)實(shí)踐經(jīng)驗(yàn)綜合提煉而成的。
- UML在演變的過程中還提出了一些新的概念,不斷推動(dòng)著OO思想的發(fā)展。
為什么著重要提這幾點(diǎn)?
面向?qū)ο驩O,是UML的根本。
你想要理解UML,想要用好UML,一定要有OO的思維方式。
這也是我為什么會(huì)在列大綱的時(shí)候就專門列了一篇關(guān)于OO的介紹。
下一篇我們?cè)僭敿?xì)來說OO。
另外,我們需要注意的是,UML還在逐步發(fā)展中。
所以時(shí)不時(shí)的新版本出來,你會(huì)發(fā)現(xiàn)由多了幾種圖,有一些新的概念。
但是其實(shí)個(gè)人覺得沒有必要去追求所謂的最新版本,因?yàn)槲覀兂S玫膸追N圖在UML2的版本中都涉及到了。
除非UML升級(jí)到UML3,否則基本上都是一些擴(kuò)展和補(bǔ)充。
我們的目的也不是進(jìn)行UML的專業(yè)研究,我們的目的是用起來。
所以呢,如果你想要買一些UML的書來看的話,關(guān)注一下書籍信息,UML1的就不要買了。
現(xiàn)在市面上大部分是UML2.3,UML2.4的。
看這個(gè)版本目前也差不多夠了。
UML組成
UML的組成主要有:事物、圖和關(guān)系。
- 事物是UML中重要的組成部分。
- 關(guān)系把各個(gè)元素緊密的聯(lián)系在一起。
- 圖是一種表達(dá)形式。
因?yàn)榉g的關(guān)系,可能有的書上不這么描述。
不過問題不大,我們這篇的主要目的是讓大家有個(gè)大體上的印象。
下面這些概念看上去比較難理解,給這種抽象的東西下定義,真的挺難的。
后面在講到具體圖的時(shí)候回一一提及。
如果看不懂,也沒關(guān)系。
UML事物
UML主要包括四種事物:構(gòu)件、行為、分組和注釋。
構(gòu)件
構(gòu)件事物是UML模型的靜態(tài)部分、描述概念或者物理元素。
包括:
類 :是對(duì)象的抽象。后面會(huì)在類圖、包圖等中進(jìn)行詳細(xì)介紹。
接口 :描述了類或組件對(duì)外可見的動(dòng)作。
協(xié)作 :一組事物相互作用的集合。
用例 :常見于用例圖,用來描述一系列動(dòng)作。
組件 :抽象了的物理或邏輯的部分。
節(jié)點(diǎn) :主要使用在部署圖中。
行為
交互 :實(shí)現(xiàn)某個(gè)功能的組件之間的消息集合。
狀態(tài)機(jī) :描述事物生命周期的狀態(tài)序列。
分組
主要由包實(shí)現(xiàn),描述事物的結(jié)構(gòu)組成。
注釋
對(duì)模型中的元素進(jìn)行說明、解釋。
關(guān)系
UML中主要的關(guān)系:依賴、關(guān)聯(lián)、泛化和實(shí)現(xiàn)。
依賴 Dependency
A元素的變化會(huì)影響B(tài)元素。
A被稱為獨(dú)立元素,被影響的B元素稱為依賴元素。
關(guān)聯(lián)Association
兩個(gè)對(duì)象之間的關(guān)系,在類圖、用例圖中很常見。
泛化Generalization
又稱為繼承,子繼承父。
在用例圖和類圖中比較常見。
實(shí)現(xiàn)Realization
條條大路通羅馬,每條路都可以實(shí)現(xiàn)到達(dá)羅馬的目的。
其他
還有一些關(guān)系會(huì)在具體降到類圖、用例圖等的時(shí)候再進(jìn)行介紹。
比如組合、聚合、包含、擴(kuò)展等等。
具體的如果感興趣,可以看《Think in UML》的第3章內(nèi)容,里面描述的比較詳盡。
UML的圖
UML包括眾多的圖,在《UML2 軟件建模:概念、規(guī)范和方法》中有這樣一張圖,看上去比較清晰,分享給大家。
主要分成兩大類:靜態(tài)圖、動(dòng)態(tài)圖(也稱為行為圖)。
靜態(tài)圖
顧名思義,描述的是對(duì)象的靜態(tài)結(jié)構(gòu),與時(shí)間無(wú)關(guān)。
動(dòng)態(tài)圖
描述的是對(duì)象的動(dòng)態(tài)行為,除用例外,其他圖會(huì)隨著時(shí)間“流動(dòng)”。
寫在最后
UML的圖其實(shí)很有意思的一點(diǎn)在于,相互獨(dú)立又相互驗(yàn)證。
如果你在畫一個(gè)用例圖,那你就應(yīng)該關(guān)注用例。
什么執(zhí)行者有哪些操作、有哪些活動(dòng)。
而不關(guān)注這些活動(dòng)的狀態(tài)和觸發(fā)條件。
但是用例圖中的這些活動(dòng)可以和活動(dòng)圖的活動(dòng)進(jìn)行對(duì)應(yīng)。
用例圖中的執(zhí)行者可以和活動(dòng)圖中的角色進(jìn)行對(duì)應(yīng)。
活動(dòng)圖中的階段可以映射到狀態(tài)機(jī)圖。
……
這也使得UML圖的維護(hù)更新比較耗費(fèi)精力。
那我們干嘛還要用UML呢?
-
建模
+關(guān)注
關(guān)注
1文章
296瀏覽量
60640 -
UML
+關(guān)注
關(guān)注
0文章
122瀏覽量
30822 -
面向?qū)ο?/span>
+關(guān)注
關(guān)注
0文章
64瀏覽量
9961
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論