UML類圖與類的關(guān)系詳解

在畫類圖的時(shí)候钝满,理清類和類之間的關(guān)系是重點(diǎn)。類的關(guān)系有泛化(Generalization)、實(shí)現(xiàn)(Realization)冒冬、依賴(Dependency)和關(guān)聯(lián)(Association)。其中關(guān)聯(lián)又分為一般關(guān)聯(lián)關(guān)系和聚合關(guān)系(Aggregation)摩渺,合成關(guān)系(Composition)简烤。下面我們結(jié)合實(shí)例理解這些關(guān)系。

基本概念

類圖(Class Diagram): 類圖是面向?qū)ο笙到y(tǒng)建模中最常用和最重要的圖摇幻,是定義其它圖的基礎(chǔ)横侦。類圖主要是用來顯示系統(tǒng)中的類、接口以及它們之間的靜態(tài)結(jié)構(gòu)和關(guān)系的一種靜態(tài)模型绰姻。

類圖的3個(gè)基本組件:類名枉侧、屬性、方法狂芋。

泛化(generalization):表示is-a的關(guān)系榨馁,是對(duì)象之間耦合度最大的一種關(guān)系,子類繼承父類的所有細(xì)節(jié)帜矾。直接使用語言中的繼承表達(dá)翼虫。在類圖中使用帶三角箭頭的實(shí)線表示屑柔,箭頭從子類指向父類。

實(shí)現(xiàn)(Realization):在類圖中就是接口和實(shí)現(xiàn)的關(guān)系珍剑。這個(gè)沒什么好講的掸宛。在類圖中使用帶三角箭頭的虛線表示,箭頭從實(shí)現(xiàn)類指向接口招拙。

依賴(Dependency):對(duì)象之間最弱的一種關(guān)聯(lián)方式唧瘾,是臨時(shí)性的關(guān)聯(lián)。代碼中一般指由局部變量别凤、函數(shù)參數(shù)饰序、返回值建立的對(duì)于其他對(duì)象的調(diào)用關(guān)系。一個(gè)類調(diào)用被依賴類中的某些方法而得以完成這個(gè)類的一些職責(zé)闻妓。在類圖使用帶箭頭的虛線表示菌羽,箭頭從使用類指向被依賴的類。

關(guān)聯(lián)(Association) : 對(duì)象之間一種引用關(guān)系由缆,比如客戶類與訂單類之間的關(guān)系注祖。這種關(guān)系通常使用類的屬性表達(dá)。關(guān)聯(lián)又分為一般關(guān)聯(lián)均唉、聚合關(guān)聯(lián)與組合關(guān)聯(lián)是晨。后兩種在后面分析。在類圖使用帶箭頭的實(shí)線表示舔箭,箭頭從使用類指向被關(guān)聯(lián)的類罩缴。可以是單向和雙向层扶。

聚合(Aggregation) : 表示has-a的關(guān)系箫章,是一種不穩(wěn)定的包含關(guān)系。較強(qiáng)于一般關(guān)聯(lián),有整體與局部的關(guān)系,并且沒有了整體,局部也可單獨(dú)存在镜会。如公司和員工的關(guān)系檬寂,公司包含員工,但如果公司倒閉戳表,員工依然可以換公司桶至。在類圖使用空心的菱形表示,菱形從局部指向整體匾旭。

組合(Composition) : 表示contains-a的關(guān)系镣屹,是一種強(qiáng)烈的包含關(guān)系。組合類負(fù)責(zé)被組合類的生命周期价涝。是一種更強(qiáng)的聚合關(guān)系女蜈。部分不能脫離整體存在。如公司和部門的關(guān)系,沒有了公司伪窖,部門也不能存在了吏廉;調(diào)查問卷中問題和選項(xiàng)的關(guān)系;訂單和訂單選項(xiàng)的關(guān)系惰许。在類圖使用實(shí)心的菱形表示,菱形從局部指向整體史辙。

多重性(Multiplicity) : 通常在關(guān)聯(lián)汹买、聚合、組合中使用聊倔。就是代表有多少個(gè)關(guān)聯(lián)對(duì)象存在晦毙。使用數(shù)字..星號(hào)(數(shù)字)表示。如下圖耙蔑,一個(gè)割接通知可以關(guān)聯(lián)0個(gè)到N個(gè)故障單见妒。

聚合和組合的區(qū)別

這兩個(gè)比較難理解,重點(diǎn)說一下甸陌。聚合和組合的區(qū)別在于:聚合關(guān)系是“has-a”關(guān)系须揣,組合關(guān)系是“contains-a”關(guān)系;聚合關(guān)系表示整體與部分的關(guān)系比較弱钱豁,而組合比較強(qiáng)耻卡;聚合關(guān)系中代表部分事物的對(duì)象與代表聚合事物的對(duì)象的生存期無關(guān),一旦刪除了聚合對(duì)象不一定就刪除了代表部分事物的對(duì)象牲尺。組合中一旦刪除了組合對(duì)象卵酪,同時(shí)也就刪除了代表部分事物的對(duì)象。

實(shí)例分析

聯(lián)通客戶響應(yīng)OSS谤碳。系統(tǒng)有故障單溃卡、業(yè)務(wù)開通、資源核查蜒简、割接瘸羡、業(yè)務(wù)重保、網(wǎng)絡(luò)品質(zhì)性能等功能模塊〕粢希現(xiàn)在我們抽出部分需求做為例子講解最铁。

大家可以參照著類圖,好好理解垮兑。

1. 通知分為一般通知冷尉、割接通知、重保通知系枪。這個(gè)是繼承關(guān)系雀哨。

2. NoticeService和實(shí)現(xiàn)類NoticeServiceImpl是實(shí)現(xiàn)關(guān)系。

3. NoticeServiceImpl通過save方法的參數(shù)引用Notice,是依賴關(guān)系。同時(shí)調(diào)用了BaseDao完成功能雾棺,也是依賴關(guān)系膊夹。

4. 割接通知和故障單之間通過中間類(通知電路)關(guān)聯(lián),是一般關(guān)聯(lián)捌浩。

5. 重保通知和預(yù)案庫間是聚合關(guān)系放刨。因?yàn)轭A(yù)案庫可以事先錄入,和重保通知沒有必然聯(lián)系尸饺,可以獨(dú)立存在进统。在系統(tǒng)中是手工從列表中選擇。刪除重保通知浪听,不影響預(yù)案螟碎。

6. 割接通知和需求單之間是聚合關(guān)系。同理迹栓,需求單可以獨(dú)立于割接通知存在掉分。也就是說刪除割接通知,不影響需求單克伊。

7. 通知和回復(fù)是組合關(guān)系酥郭。因?yàn)榛貜?fù)不能獨(dú)立于通知存在。也就是說刪除通知答毫,該條通知對(duì)應(yīng)的回復(fù)也要級(jí)聯(lián)刪除褥民。

經(jīng)過以上的分析,相信大家對(duì)類的關(guān)系已經(jīng)有比較好的理解了洗搂。大家有什么其它想法或好的見解消返,歡迎拍磚。

PS:還是那句話:以上類圖用Enterprise Architect 7.5所畫耘拇,在此推薦一下EA,非常不錯(cuò)撵颊。可以替代Visio和Rose了惫叛。Visio功能不夠強(qiáng)大倡勇,Rose太重。唯有EA比較合適嘉涌。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末妻熊,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子仑最,更是在濱河造成了極大的恐慌扔役,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件警医,死亡現(xiàn)場(chǎng)離奇詭異亿胸,居然都是意外死亡坯钦,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門侈玄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來婉刀,“玉大人,你說我怎么就攤上這事序仙⊥患眨” “怎么了?”我有些...
    開封第一講書人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵潘悼,是天一觀的道長(zhǎng)洋丐。 經(jīng)常有香客問我,道長(zhǎng)挥等,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任堤尾,我火速辦了婚禮肝劲,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘郭宝。我一直安慰自己辞槐,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開白布粘室。 她就那樣靜靜地躺著榄檬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪衔统。 梳的紋絲不亂的頭發(fā)上鹿榜,一...
    開封第一講書人閱讀 49,837評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音锦爵,去河邊找鬼舱殿。 笑死,一個(gè)胖子當(dāng)著我的面吹牛险掀,可吹牛的內(nèi)容都是我干的沪袭。 我是一名探鬼主播,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼樟氢,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼冈绊!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起埠啃,我...
    開封第一講書人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬榮一對(duì)情侶失蹤死宣,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后霸妹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體十电,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鹃骂。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片台盯。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖畏线,靈堂內(nèi)的尸體忽然破棺而出静盅,到底是詐尸還是另有隱情,我是刑警寧澤寝殴,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布蒿叠,位于F島的核電站,受9級(jí)特大地震影響蚣常,放射性物質(zhì)發(fā)生泄漏市咽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一抵蚊、第九天 我趴在偏房一處隱蔽的房頂上張望施绎。 院中可真熱鬧,春花似錦贞绳、人聲如沸谷醉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽俱尼。三九已至,卻和暖如春萎攒,著一層夾襖步出監(jiān)牢的瞬間遇八,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來泰國打工耍休, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留押蚤,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓羹应,卻偏偏與公主長(zhǎng)得像揽碘,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子园匹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容

  • 在UML 2.0的13種圖形中雳刺,類圖是使用頻率最高的UML圖之一。Martin Fowler在其著作《UML Di...
    雷雷_zll閱讀 13,226評(píng)論 0 14
  • 忘記了uml類圖連線之間的關(guān)系裸违,記錄一下掖桦。 1. 關(guān)聯(lián)關(guān)系 關(guān)聯(lián)(Association)關(guān)系是類與類之間最常用的...
    cutieagain閱讀 1,820評(píng)論 0 2
  • UML類圖是一種結(jié)構(gòu)圖,用于描述一個(gè)系統(tǒng)的靜態(tài)結(jié)構(gòu)供汛。類圖以反映類結(jié)構(gòu)和類之間關(guān)系為目的枪汪,用以描述軟件系統(tǒng)的結(jié)構(gòu)涌穆,是...
    美虎轆轆閱讀 630評(píng)論 0 0
  • UML概述 UML簡(jiǎn)介 UML (Unified Modeling Language)為面向?qū)ο筌浖O(shè)計(jì)提供統(tǒng)一的...
    aron1992閱讀 512評(píng)論 0 0
  • 1.提高自控力,拒絕拖延雀久! 2.增強(qiáng)口頭表達(dá)能力宿稀,如何將文字表達(dá)轉(zhuǎn)化為口頭表述,使你可以像書寫文字一樣赖捌,有空間和時(shí)...
    段子手王爾德閱讀 293評(píng)論 0 2