介紹
UML(統一建模語言)時序圖是一種用於模擬物件隨時間行為的互動圖。它在實時系統中特別有用,因為時序限制和生命線至關重要。本指南將介紹時序圖的兩種形式:狀態/條件生命線與一般值生命線。我們將探討關鍵概念,提供範例,並比較兩種形式。
關鍵概念
生命線
生命線代表互動中的單一參與者。它以垂直線表示,顯示物件在時間上的存在。
狀態/條件
狀態或條件是物件可能處於的不同模式或情境。它們以生命線上的水平線段表示。
持續時間限制
持續時間限制指定特定狀態或轉移的時間長度。它們以帶有註解的水平線表示,標示時間範圍。
時間訊息
時間訊息是發生在特定時間點的生命線之間的互動。它們以連接生命線的水平箭頭表示。
時序框
時序框是一個矩形框,包圍整個時序圖,為時序限制和互動提供上下文。
狀態/條件生命線
描述
狀態/條件生命線符號將狀態以清單形式顯示在相關參與者旁邊。接著需要一條狀態線來顯示參與者在特定時間所處的狀態。這種形式適用於狀態數量有限的系統。
時序圖範例
完整檢視與精簡檢視

說明
- 參與者1:
- 狀態/條件1:初始狀態。
- 狀態/條件2:1秒後轉移。
- 狀態/條件3:再過1秒後轉移。
- 狀態/條件4:持續時間限制之前的最終狀態。
- 參與者2:
- 狀態/條件1:初始狀態。
- 狀態/條件2:接收後的轉移
訊息1. - 狀態/條件3:最終狀態。
- 持續時間限制:整個互動必須在5秒內完成。
- 時間訊息:
訊息1由參與者1發送到參與者2。
優點
- 清晰度:對於狀態較少的系統來說容易理解。
- 精確度:清楚地顯示狀態隨時間的順序。
缺點
- 空間:隨著狀態數量增加,需要更多空間。
- 複雜性:當參與者和狀態數量很多時,可能變得複雜。
通用值生命線
描述
通用值生命線符號將參與者的狀態直接放置在該參與者處於該狀態的時間點。這種形式消除了對狀態線的需求,並允許所有狀態在圖表中單一行內排列。
範例
說明
- 參與者1:
- 狀態/條件4:初始狀態。
- 狀態/條件3:1秒後轉換。
- 狀態/條件2:再過1秒後轉換。
- 狀態/條件1:持續時間限制前的最終狀態。
- 參與者2:
- 狀態/條件1:初始狀態。
- 狀態/條件2:接收後轉換
訊息1. - 狀態/條件3:最終狀態。
- 持續時間限制:整個互動必須在5秒內完成。
- 時間訊息:
訊息1由參與者1傳送至參與者2。
優勢
- 空間效率:所需空間較少,特別是在狀態較多時。
- 簡單性:在複雜系統中更容易管理。
缺點
- 可讀性:對於剛接觸時序圖的人來說可能不太直觀。
- 細節:在顯示狀態隨時間的變化序列方面較為簡略。
比較
空間效率
- 狀態/條件生命線:隨著狀態數量增加,需要更多空間。
- 一般值生命線:空間效率更高,尤其是在狀態較多時。
可讀性
- 狀態/條件生命線:對於狀態較少的系統來說更容易理解。
- 一般值生命線:可能不太直觀,但在複雜系統中更易於管理。
複雜性
- 狀態/條件生命線:當參與者和狀態數量很多時,可能變得複雜。
- 一般值生命線:在複雜系統中更容易管理。
精確度
- 狀態/條件生命線:清楚地顯示狀態隨時間的變化序列。
- 一般值生命線:在顯示狀態序列方面較為簡略。
以下是UML時序圖中狀態/條件生命線與一般值生命線比較的總結表格:
| 特徵 | 狀態/條件生命線 | 一般值生命線 |
|---|---|---|
| 狀態表示 | 狀態列於參與者旁邊,並以狀態線標示。 | 狀態直接標示於單一時間點上。 |
| 空間效率 | 隨著狀態數量增加,需要更多空間。 | 更具空間效率,特別是在狀態數量較多時。 |
| 可讀性 | 對於狀態較少的系統較容易理解。 | 可能較不直覺,但對於複雜系統更易於管理。 |
| 複雜度管理 | 當參與者與狀態數量眾多時,可能變得複雜。 | 對於複雜系統更易於管理。 |
| 精確度 | 清楚顯示狀態隨時間的順序。 | 在顯示狀態順序方面較不詳細。 |
| 使用案例 | 適用於狀態數量有限的系統。 | 適用於具有許多狀態與複雜互動的系統。 |
| 視覺清晰度 | 提供清晰的狀態轉換視覺序列。 | 提供狀態隨時間的緊湊視覺表示。 |
| 註解 | 每個狀態轉換都需要註解。 | 需要較少的註解,專注於關鍵互動。 |
| 可擴展性 | 隨著狀態數量增加,可擴展性較低。 | 隨著狀態數量增加,更具可擴展性。 |
此表格提供快速參考,以理解 UML 時間圖中每種生命線的關鍵差異與使用案例。
技巧與提示
- 清晰度:確保圖表清晰易懂。使用一致的符號和標籤。
- 精確度:在持續時間限制和時間訊息方面要精確。使用註解來指定精確的時間和條件。
- 簡潔性:保持圖表簡潔。專注於與情境相關的重要互動和狀態。
- 一致性:與專案中其他UML圖表保持一致。使用相同的命名規範和風格。
- 驗證:與利益相關者共同驗證時序圖,以確保其準確反映系統的行為。
結論
UML時序圖是用於模擬即時系統行為的強大工具。透過理解狀態/條件生命線與一般值生命線之間的關鍵概念與差異,您可以創建有效的時序圖,以協助複雜系統的設計與驗證。選擇最適合您系統複雜度和所需細節層級的形式。
參考資料
- 什麼是時序圖?
- Visual Paradigm。(未注明日期)。什麼是時序圖? .
- 12. 時序圖 – Visual Paradigm 社區圈
- Visual Paradigm 社區圈。(2018年5月11日)。時序圖 – Visual Paradigm 社區圈 .
- 如何繪製時序圖?
- Visual Paradigm。(未注明日期)。如何繪製時序圖? .
- 時間限制時序圖 – UML – 討論 Visual Paradigm
- Visual Paradigm 論壇。(2019年7月19日)。時間限制時序圖 – UML – 討論 Visual Paradigm .
- Visual Paradigm 中的 UML 圖表入門 – ArchiMetric
- ArchiMetric. (2024年8月23日). Visual Paradigm 中的 UML 圖表入門 – ArchiMetric .
- 時序圖,UML 圖表範例:狀態/條件時間軸 – Visual Paradigm 社區圈
- Visual Paradigm 社區圈. (2018年9月24日). 時序圖,UML 圖表範例:狀態/條件時間軸 – Visual Paradigm 社區圈 .
- UML 實用指南 – 了解 UML 建模所需的一切
- Visual Paradigm. (未注明日期). UML 實用指南 – 了解 UML 建模所需的一切 .
- 時序圖 – UML 2 圖表 – UML 建模工具
- Visual Paradigm. (未注明日期). 時序圖 – UML 2 圖表 – UML 建模工具 .
- 時序圖 – Visual Paradigm 社區圈
- Visual Paradigm 社區圈. (未注明日期). 時序圖 – Visual Paradigm 社區圈 .












