www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 公眾號精選 > C語言編程
[導讀]軟件設(shè)計時序圖制作工具在軟件設(shè)計過程中,經(jīng)常會使用到時序圖來表達模塊之間的交互、信息傳遞的動態(tài)行為或者其他軟件邏輯。時序圖可以清晰地表達軟件層面的設(shè)計,甚至毫不夸張說是“一圖頂千言”。那么,拋出個直截了當?shù)膯栴}:畫時序圖的工具有哪些?哪個最好用?以下以EA(EnterpriseA...

軟件設(shè)計時序圖制作工具

在軟件設(shè)計過程中,經(jīng)常會使用到時序圖來表達模塊之間的交互、信息傳遞的動態(tài)行為或者其他軟件邏輯。時序圖可以清晰地表達軟件層面的設(shè)計,甚至毫不夸張說是“一圖頂千言”。

那么,拋出個直截了當?shù)膯栴}:畫時序圖的工具有哪些?哪個最好用?

以下以EA(Enterprise Architect)DrawIO、PlantUML和Markdown里的mermaid來對比講解。

首先看看他們的效果對比:

1. 效果對比

以下是EA(Enterprise Architect)、DrawIO、PlantUML和Markdown里的mermaid的時序圖最終效果對比。

這幾個圖都是表示創(chuàng)建一個賬戶(Create Account)的實例。

This Sequence Diagram shows the Objects involved in the creation of a new account. The Account Object is displayed lower down in the diagram because it doesn’t exist at the beginning of the sequence but is created as a result of the message.

  1. EA

  2. DrawIO

  3. PlantUML

  4. mermaid


從上面的各個工具做出的圖看,前面三個差別不大該有的圖示效果都有,最后一個mermaid就沒那么豐富了,只能做個簡單的圖示表達。

然而,這樣也不能說明哪個是最好的,只能從中找出一個最適合你的。

為了更好說明各自的優(yōu)缺點,先看看時序圖里面有什么。

2. 時序圖的組成

首先,想想你理解中的時序圖是什么?里面有什么元素?

畫兩根豎線,然后通過幾個箭頭表示消息傳遞,僅此而已?

這個是時序圖么?是,可以認為時序圖,但不是那么標準。

那么,什么是標準?或者說有沒有一個約定成俗的東西?

時序圖不僅僅是給自己看的,也是向其他團隊成員傳遞或表達信息的媒介,應(yīng)該與別人有共同約定的符號或元素。

就像南方人跟北方人講話,通用的普通話就很好,如果你講的普通話夾雜很多粵語甚至潮汕話,你讓東北人怎么聽得懂。

時序圖是可以基于UML的,UML是統(tǒng)一建模語言,里面很多元素是我們共同認為它表達某一種特別含義。

以下基于UML概念,講講時序圖里面主要一些元素。

Lifeline

這個是時序圖的最基本的東西

Lifeline是交互中的單個參與者(即生命線不能具有多重性)。Lifeline代表一個獨特的可連接元素。

OMG UML 規(guī)范(UML Superstructure Specification, v2.1.1, p.489)指出:

Lifeline代表交互中的單個參與者。雖然零件和結(jié)構(gòu)特征的多重性可能大于 1,但Lifeline僅代表一個交互實體。

這個很好理解,簡單粗暴地說,就是一根豎下來的東西,代表一個獨立的交互實體。

上圖是EA常用的Lifeline圖示,當然也有通過其他圖標組合的Lifeline,例如這個

DrawIO上也能找到很多各種Lifeline

對于PlantUML,可以通過腳本指定,同樣有很多種

下圖示例Lifeline類型
Foo1actor
Foo2boundary
Foo3control
Foo4entity
Foo5database
Foo6collections

而mermaid就沒有那么多類型的了,就只有很簡單的。

Control/Boundary/Entity

Control 是一個原型對象,它為控制實體或管理器建模。控件組織和安排其他活動和元素,通常在分析(包括穩(wěn)健性)、序列和通信圖中。


Boundary是一種原型對象,它對某些系統(tǒng)Boundary進行建模,通常是用戶界面屏幕。您還可以將Boundary創(chuàng)建為構(gòu)造型類。在分析中使用Boundary元素來捕獲用戶交互、屏幕流和元素交互(或“協(xié)作”)。
在概念階段使用Boundary來捕獲用戶在屏幕級別(或某些其他Boundary界面類型)與系統(tǒng)交互。它通常用于序列和穩(wěn)健性(分析)圖中。

Entity是一種原型對象,它對捕獲系統(tǒng)中的信息或知識的存儲或持久性機制進行建模。

通常情況下,Control/Boundary/Entity往往跟Lifeline一起使用(見文章開頭的圖)。

EA、DrawIO、PlantUML都有這些元素。

Message

這個很好理解,就是一根線一個箭頭,加上一個文本描述。

Message表示元素之間的信息流或控制轉(zhuǎn)換。
Message可用于時序圖、序列圖和通信圖(但不包括交互概覽圖)以反映系統(tǒng)行為。
如果在類或分類器實例之間,關(guān)聯(lián)的操作列表可用于指定事件。

Message分Synchronize和Asynchronize,前者對應(yīng)的是黑實心箭頭(下圖右邊的箭頭),后者對應(yīng)的是開放箭頭(下圖左邊的箭頭)。

對于EA,可以直接雙擊這個message箭頭可以設(shè)置,里面的配置十分豐富

而DrawIO或其他工具,在設(shè)置屬性等界面可以選擇不同的箭頭,而并沒說明這是Synchronize還是Asynchronize。

對于PlantUML,是通過腳本設(shè)置不同的Message類型,如

  • Client ->> CreateAccount表示Asynchronize箭頭;

  • CreateAccount -> CreateNewAccount表示Synchronize箭頭。

另外,這兩種不同的Message類型,會影響Lifeline的,很明顯Synchronize會阻塞當前運行,而Asynchronize不會。

這個圖上的block塊,在EA上是自動根據(jù)Message類型顯示的,不需要特殊處理,而DrawIO是需要在Lifeline上貼上一個長方形的,但是PlantUML上似乎沒找到這個設(shè)置。

Fragment

組合Fragment反映了由交互操作符控制的交互(稱為交互操作數(shù))的一個或多個方面,相應(yīng)的布爾條件稱為交互約束。Fragment 顯示為一個透明窗口,由每個操作數(shù)的水平線分隔。

下圖說明了如何使用組合片段對簡化的采購流程進行建模。Loop Fragment表示迭代購買數(shù)量未知的物品,之后收銀員請求付款。
另一個Fragment代表支付選項,該Fragment被分割以顯示現(xiàn)金和信用卡這兩個操作數(shù)。在Fragment完成其跟蹤后,收銀員在滿足付款要求的履行條件下向客戶提供收據(jù)。

在EA上操作Fragment是非常方便的。

而在DrawIO上的話,有點古板,里面的線條或者邊框都是普通圖形組成的,如果有比較復雜的Fragment要畫,是比較麻煩的。

對于PlantUML,它是有專門的語法對應(yīng)這個Fragment的,例如下面這段腳本就可以翻譯成以下圖形:

@startuml
Alice -> Bob: Authentication Request
alt successful case
Bob -> Alice: Authentication Accepted
else some kind of failure
Bob -> Alice: Authentication Failure
group My own label
Alice -> Log : Log attack start
loop 1000 times
Alice -> Bob: DNS Attack
end
Alice -> Log : Log attack end
end
else Another type of failure
Bob -> Alice: Please repeat
end
@enduml

注釋

這個沒什么特殊的,不是很講究,簡單地理解就是在時序圖上貼上一段文本內(nèi)容,以輔助理解這個時序圖。

3. 總結(jié)

工具/軟件時序圖功能總結(jié)評價
EA這個是基于UML概念設(shè)計用的,不僅僅是為了畫圖,而注重“設(shè)計”。里面的概念和功能非常強大,畫時序圖也非常友好,但是如果對EA陌生的話,入門會有些難度,相對DrawIO并非“所見所得”。
DrawIO畫的圖很好看,也很方便,就因為圖是“畫”出來的,所以,它是為了畫圖而畫圖,并沒有太多內(nèi)涵。如果畫很復雜的圖也是比較繁瑣的。如果只是畫些簡單的圖形,是不二選擇。
PlantUMLUML概念比較豐富,但是顏色風格看個人喜好。如果喜歡Mark圖而不是畫圖的,可以考慮。這個工具“畫”圖是通過腳本命令的,然后生成圖片。經(jīng)常使用文本編輯的環(huán)境,這個是比較好的。
mermaid非常簡單,功能稀少,用于嵌入markdown的簡單圖示是個不錯的選擇
總體來說,如果僅僅是畫時序圖,我優(yōu)先選EA,對于簡單的而又好看點的,就選DrawIO。

注意:EA軟件是要license的,而DrawIO是開源的。DrawIO有網(wǎng)頁版、PC桌面版,也有vs code插件版。
PlantUML,我是用vs code插件來做的。mermaid的話,我用Typera markdown。


本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉