完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>
標(biāo)簽 > UML
Unified Modeling Language (UML)又稱統(tǒng)一建模語言或標(biāo)準(zhǔn)建模語言,是始于1997年一個OMG標(biāo)準(zhǔn),它是一個支持模型化和軟件系統(tǒng)開發(fā)的圖形化語言,為軟件開發(fā)的所有階段提供模型化和可視化支持,包括由需求分析到規(guī)格,到構(gòu)造和配置。
Unified Modeling Language (UML)又稱統(tǒng)一建模語言或標(biāo)準(zhǔn)建模語言,是始于1997年一個OMG標(biāo)準(zhǔn),它是一個支持模型化和軟件系統(tǒng)開發(fā)的圖形化語言,為軟件開發(fā)的所有階段提供模型化和可視化支持,包括由需求分析到規(guī)格,到構(gòu)造和配置。 面向?qū)ο蟮姆治雠c設(shè)計(jì)(OOA&D,OOAD)方法的發(fā)展在80年代末至90年代中出現(xiàn)了一個高潮,UML是這個高潮的產(chǎn)物。它不僅統(tǒng)一了Booch、Rumbaugh和Jacobson的表示方法,而且對其作了進(jìn)一步的發(fā)展,并最終統(tǒng)一為大眾所接受的標(biāo)準(zhǔn)建模語言。
Grady Booch的描述對象集合和它們之間的關(guān)系的方法。James Rumbaugh的對象建模技術(shù)(OMT)。Ivar Jacobson的包括用例方法的方式。還有其他一些想法也對UML起到了作用,UML是Booch, Rumbaugh, Jacobson。UML已經(jīng)被對象管理組織(OMG)接受為標(biāo)準(zhǔn),這個組織還制定了通用對象請求代理體系結(jié)構(gòu)(CORBA),是分布式對象編程行業(yè)的領(lǐng)頭羊。計(jì)算機(jī)輔助軟件工程(CASE)產(chǎn)品的供應(yīng)商也支持UML,并且它基本上已經(jīng)被所有的軟件開發(fā)產(chǎn)品制造商所認(rèn)可,這其中包括IBM和微軟(用于它的VB環(huán)境)。
UML規(guī)范用來描述建模的概念有,類(對象的)、對象、關(guān)聯(lián)、職責(zé)、行為、接口、用例、包、順序、協(xié)作,以及狀態(tài)。
Unified Modeling Language (UML)又稱統(tǒng)一建模語言或標(biāo)準(zhǔn)建模語言,是始于1997年一個OMG標(biāo)準(zhǔn),它是一個支持模型化和軟件系統(tǒng)開發(fā)的圖形化語言,為軟件開發(fā)的所有階段提供模型化和可視化支持,包括由需求分析到規(guī)格,到構(gòu)造和配置。 面向?qū)ο蟮姆治雠c設(shè)計(jì)(OOA&D,OOAD)方法的發(fā)展在80年代末至90年代中出現(xiàn)了一個高潮,UML是這個高潮的產(chǎn)物。它不僅統(tǒng)一了Booch、Rumbaugh和Jacobson的表示方法,而且對其作了進(jìn)一步的發(fā)展,并最終統(tǒng)一為大眾所接受的標(biāo)準(zhǔn)建模語言。
Grady Booch的描述對象集合和它們之間的關(guān)系的方法。James Rumbaugh的對象建模技術(shù)(OMT)。Ivar Jacobson的包括用例方法的方式。還有其他一些想法也對UML起到了作用,UML是Booch, Rumbaugh, Jacobson。UML已經(jīng)被對象管理組織(OMG)接受為標(biāo)準(zhǔn),這個組織還制定了通用對象請求代理體系結(jié)構(gòu)(CORBA),是分布式對象編程行業(yè)的領(lǐng)頭羊。計(jì)算機(jī)輔助軟件工程(CASE)產(chǎn)品的供應(yīng)商也支持UML,并且它基本上已經(jīng)被所有的軟件開發(fā)產(chǎn)品制造商所認(rèn)可,這其中包括IBM和微軟(用于它的VB環(huán)境)。
UML規(guī)范用來描述建模的概念有,類(對象的)、對象、關(guān)聯(lián)、職責(zé)、行為、接口、用例、包、順序、協(xié)作,以及狀態(tài)。
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個基本組件:類名、屬性、方法。
泛化(generalization):表示is-a的關(guān)系,是對象之間耦合度最大的一種關(guān)系,子類繼承父類的所有細(xì)節(jié)。直接使用語言中的繼承表達(dá)。在類圖中使用帶三角箭頭的實(shí)線表示,箭頭從子類指向父類。
實(shí)現(xiàn)(Realization):在類圖中就是接口和實(shí)現(xiàn)的關(guān)系。這個沒什么好講的。在類圖中使用帶三角箭頭的虛線表示,箭頭從實(shí)現(xiàn)類指向接口。
依賴(Dependency):對象之間最弱的一種關(guān)聯(lián)方式,是臨時(shí)性的關(guān)聯(lián)。代碼中一般指由局部變量、函數(shù)參數(shù)、返回值建立的對于其他對象的調(diào)用關(guān)系。一個類調(diào)用被依賴類中的某些方法而得以完成這個類的一些職責(zé)。在類圖使用帶箭頭的虛線表示,箭頭從使用類指向被依賴的類。
關(guān)聯(lián)(Association) : 對象之間一種引用關(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)的類??梢允菃蜗蚝碗p向。
聚合(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)、聚合、組合中使用。就是代表有多少個關(guān)聯(lián)對象存在。使用數(shù)字。。星號(數(shù)字)表示。如下圖,一個割接通知可以關(guān)聯(lián)0個到N個故障單。
聚合和組合的區(qū)別
這兩個比較難理解,重點(diǎn)說一下。聚合和組合的區(qū)別在于:聚合關(guān)系是“has-a”關(guān)系,組合關(guān)系是“contains-a”關(guān)系;聚合關(guān)系表示整體與部分的關(guān)系比較弱,而組合比較強(qiáng);聚合關(guān)系中代表部分事物的對象與代表聚合事物的對象的生存期無關(guān),一旦刪除了聚合對象不一定就刪除了代表部分事物的對象。組合中一旦刪除了組合對象,同時(shí)也就刪除了代表部分事物的對象。
實(shí)例分析
聯(lián)通客戶響應(yīng)OSS。系統(tǒng)有故障單、業(yè)務(wù)開通、資源核查、割接、業(yè)務(wù)重保、網(wǎng)絡(luò)品質(zhì)性能等功能模塊。現(xiàn)在我們抽出部分需求做為例子講解。
大家可以參照著類圖,好好理解。
1. 通知分為一般通知、割接通知、重保通知。這個是繼承關(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ú)立于通知存在。也就是說刪除通知,該條通知對應(yīng)的回復(fù)也要級聯(lián)刪除。
經(jīng)過以上的分析,相信大家對類的關(guān)系已經(jīng)有比較好的理解了。大家有什么其它想法或好的見解,歡迎拍磚。
PS:還是那句話:以上類圖用Enterprise Architect 7.5所畫,在此推薦一下EA,非常不錯??梢蕴娲鶹isio和Rose了。Visio功能不夠強(qiáng)大,Rose太重。唯有EA比較合適。
UML 還有用嗎
有用的,主要用在設(shè)計(jì)和分析階段,但是 UML 不適合用來做代碼生成。
從這個問題里,也正好發(fā)現(xiàn)了一個有意思的事兒:圖形化的方式傳達(dá)信息的能力很強(qiáng),但是通過圖形化語言去做編程反而很困難。代碼生成或者說技術(shù)效率的提升,一直以來靠得其實(shí)是 DSL。
UML 有幾種圖
UML 有幾種圖?第一反應(yīng)是不是類圖?其實(shí),還有用例圖、順序圖、活動圖、狀態(tài)圖、組件圖等。這里提到的每一種圖,都代表著工程的一個特定維度,它們的專注點(diǎn)是正交的,都有其獨(dú)特的用處。使用 UML 來分析和設(shè)計(jì),可以讓大家對整個系統(tǒng)有個更全面的認(rèn)知。
用例圖
拿用例圖來說,它衡量的是 1) 系統(tǒng)內(nèi)部的功能結(jié)構(gòu) 2) 外部系統(tǒng)和用戶的對接關(guān)系。
「和外部系統(tǒng)對接」,這是整個工程中最薄弱的環(huán)節(jié),就好比汽車各系統(tǒng)零部件之間的結(jié)合處,非常脆弱而且容易磨損老化。外部系統(tǒng)對接的復(fù)雜程度是衡量工程風(fēng)險(xiǎn)和工作量的一項(xiàng)重要指標(biāo),如果沒有用例圖這樣的工具和針對外部系統(tǒng)對接關(guān)系進(jìn)行分析的意識,那后期會有很多坑。
你是不是只熟悉類圖
UML 初學(xué)者最容易犯的錯誤就是太在意類圖,卻忽略其他。類圖是一種“靜態(tài)”設(shè)計(jì),像順序圖、協(xié)作圖、活動圖則是對系統(tǒng)的一種“動態(tài)”設(shè)計(jì),體現(xiàn)的是二進(jìn)制世界中的實(shí)際場景。我們經(jīng)常使用順序圖來設(shè)計(jì)、分析關(guān)鍵流程,有哪些模塊參與,分別承擔(dān)什么責(zé)任,彼此之間如何調(diào)用?;顒訄D通常被人拿來描述復(fù)雜的業(yè)務(wù)流程。
狀態(tài)圖,狀態(tài)圖的用處就廣泛了,常用來分析組件的生命周期,而且用途不僅僅局限在敲代碼:PM 可以拿它來設(shè)計(jì)頁面跳轉(zhuǎn)邏輯,Growth Hacker 可以拿它設(shè)計(jì)和分析用戶轉(zhuǎn)化模型,工程師可以用它來吊打邏輯不清晰的產(chǎn)品經(jīng)理。
最后,附上一張 Android MediaPlayer 的狀態(tài)圖,相信很多 Android 工程師都比較眼熟吧 :)
實(shí)踐GoF的23種設(shè)計(jì)模式實(shí)現(xiàn):橋接模式
也即,將抽象部分和實(shí)現(xiàn)部分進(jìn)行解耦,使得它們能夠各自往獨(dú)立的方向變化。
2024-04-14 標(biāo)簽:UML數(shù)據(jù)處理go語言 401 0
實(shí)踐GoF的23種設(shè)計(jì)模式:解釋器模式
解釋器模式(Interpreter Pattern)應(yīng)該是 GoF 的 23 種設(shè)計(jì)模式中使用頻率最少的一種了,它的應(yīng)用場景較為局限。
2024-04-01 標(biāo)簽:DSL數(shù)據(jù)存儲SQL 607 0
封裝了自身的數(shù)據(jù)和行為,能獨(dú)立對外提供服務(wù)的東西才能稱為系統(tǒng)。需要注意的系統(tǒng)是一個整體,系統(tǒng)可能會有很多子系統(tǒng)。比如銀行轉(zhuǎn)賬交易時(shí)候需要做風(fēng)控,如果有商...
實(shí)踐GoF的23種設(shè)計(jì)模式:備忘錄模式
相對于代理模式、工廠模式等設(shè)計(jì)模式,備忘錄模式(Memento)在我們?nèi)粘i_發(fā)中出鏡率并不高,除了應(yīng)用場景的限制之外,另一個原因,可能是備忘錄模式
sqlite工具包提供兩種數(shù)據(jù)插入方式,全部使用Execute SQL(Ploy)函數(shù)
對復(fù)雜系統(tǒng)的建模是架構(gòu)師的基礎(chǔ)能力之一。從這篇文章開始,筆者介紹系統(tǒng)建模語言SysML(OMG System Modeling Language)。 ...
2023-09-01 標(biāo)簽:UML建模軟件結(jié)構(gòu)圖 6464 0
如何設(shè)計(jì)時(shí)序圖—以APA自動泊車系統(tǒng)為例(一)
序列圖是一種 UML(統(tǒng)一建模語言)圖,它說明了系統(tǒng)中對象之間隨時(shí)間的交互,通常用于可視化消息流和軟件系統(tǒng)中對象之間方法調(diào)用的順序。
狀態(tài)機(jī)編程實(shí)例-嵌套switch-case法
嵌入式軟件開發(fā)中,狀態(tài)機(jī)編程是一個比較實(shí)用的代碼實(shí)現(xiàn)方式,特別適用于事件驅(qū)動的系統(tǒng)。本篇,以一個炸彈拆除的小游戲?yàn)槔?,介紹狀態(tài)機(jī)編程的思路。
本篇介紹了UML時(shí)序圖的基礎(chǔ)知識,并通過visio繪制一個物聯(lián)網(wǎng)設(shè)備WIFI配網(wǎng)的UML時(shí)序圖實(shí)例,來介紹UML時(shí)序圖的畫法與所表達(dá)的含義。
2023-05-16 標(biāo)簽:嵌入式物聯(lián)網(wǎng)UML 2105 0
高煥堂《嵌入式UML設(shè)計(jì)》讀書筆記_第一章立即下載
類別:嵌入式開發(fā) 2021-11-03 標(biāo)簽:嵌入式嵌入式設(shè)計(jì)UML
智能化無線測溫預(yù)警系統(tǒng)分析與設(shè)計(jì)立即下載
類別:傳感器技術(shù)論文 2020-01-14 標(biāo)簽:傳感器數(shù)據(jù)采集UML
嵌入式系統(tǒng)教程之嵌入式系統(tǒng)工程設(shè)計(jì)的詳細(xì)資料說明立即下載
類別:嵌入式開發(fā) 2019-07-23 標(biāo)簽:嵌入式系統(tǒng)UML函數(shù)
架構(gòu)開發(fā)與優(yōu)化咨詢和實(shí)施服務(wù)
得益于硬件平臺算力的提升,汽車電子電氣架構(gòu)的集成度逐漸提高,多域融合成為了目前行業(yè)中軟件工程的重要工作內(nèi)容。經(jīng)緯恒潤可以為汽車電子和軟件工程師在開發(fā)軟件...
Rhapsody—復(fù)雜域控軟件架構(gòu)開發(fā)套件
Rhapsody是基于UML/SysML的模型驅(qū)動開發(fā)集成環(huán)境,專注于嵌入式和實(shí)時(shí)系統(tǒng)。通過Rhapsody的模型驅(qū)動體系,可以快速地將應(yīng)用模型部署到實(shí)...
統(tǒng)一建模語言(Unified Modeling Language,UML)是用來設(shè)計(jì)軟件藍(lán)圖的可視化建模語言,1997 年被國際對象管理組織(OMG)采...
2023-05-05 標(biāo)簽:建模UML面向?qū)ο?/a> 609 0
目的是統(tǒng)一語言,減少溝通障礙,簡單說就是名詞解釋,如果一個術(shù)語比較復(fù)雜,要用why,what,how來解釋清楚,這三個東西不是每個術(shù)語都得寫,要看某一項(xiàng)...
我們經(jīng)常會遇到“給現(xiàn)有對象/模塊新增功能”的場景,比如 http router 的開發(fā)場景下,除了最基礎(chǔ)的路由功能之外,我們常常還會加上如日志、鑒權(quán)、流...
典型的模型由子模型的聚合組成。每個子模型是一個部分描述,并為特定的目的而創(chuàng)建;它可能由一個或多個圖組成。子模型的集合可以使用多種建模語言或單一的建模語言...
要比較靈活的使用C語言實(shí)現(xiàn)一些高層級的框架時(shí),需要掌握一些進(jìn)階編程技巧,這篇來談?wù)剉oid指針的一些妙用。測試環(huán)境采用 IAR for ARM 8.40...
程序員都應(yīng)學(xué)習(xí)的語言:看25張圖學(xué)UML
[導(dǎo)讀] 作為程序猿都最好掌握的一門語言,那就是UML(Unified Modeling Language),統(tǒng)一建模語言(UML)是軟件工程領(lǐng)域中一種...
2020-12-14 標(biāo)簽:UML深度學(xué)習(xí) 522 0
走馬觀花的將UML大致梳理了一下,并結(jié)合EA的例圖
到UML不得不提的三位大神,Grady Booch、Jacobson、James Rumbaugh,三位是UML的創(chuàng)始人,均為軟件工程界的權(quán)威,除了著有...
2020-07-01 標(biāo)簽:UML可視化系統(tǒng) 2433 0
編輯推薦廠商產(chǎn)品技術(shù)軟件/工具OS/語言教程專題
電機(jī)控制 | DSP | 氮化鎵 | 功率放大器 | ChatGPT | 自動駕駛 | TI | 瑞薩電子 |
BLDC | PLC | 碳化硅 | 二極管 | OpenAI | 元宇宙 | 安森美 | ADI |
無刷電機(jī) | FOC | IGBT | 逆變器 | 文心一言 | 5G | 英飛凌 | 羅姆 |
直流電機(jī) | PID | MOSFET | 傳感器 | 人工智能 | 物聯(lián)網(wǎng) | NXP | 賽靈思 |
步進(jìn)電機(jī) | SPWM | 充電樁 | IPM | 機(jī)器視覺 | 無人機(jī) | 三菱電機(jī) | ST |
伺服電機(jī) | SVPWM | 光伏發(fā)電 | UPS | AR | 智能電網(wǎng) | 國民技術(shù) | Microchip |
Arduino | BeagleBone | 樹莓派 | STM32 | MSP430 | EFM32 | ARM mbed | EDA |
示波器 | LPC | imx8 | PSoC | Altium Designer | Allegro | Mentor | Pads |
OrCAD | Cadence | AutoCAD | 華秋DFM | Keil | MATLAB | MPLAB | Quartus |
C++ | Java | Python | JavaScript | node.js | RISC-V | verilog | Tensorflow |
Android | iOS | linux | RTOS | FreeRTOS | LiteOS | RT-THread | uCOS |
DuerOS | Brillo | Windows11 | HarmonyOS |