UML建模——用例圖(Use Case Diagram)

yinghualeihenmei發表於2024-03-19

原文連結:https://www.cnblogs.com/lcword/p/10472040.html

用例圖主要用來描述角色以及角色與用例之間的連線關係。說明的是誰要使用系統,以及他們使用該系統可以做些什麼。一個用例圖包含了多個模型元素,如系統、參與者和用例,並且顯示這些元素之間的各種關係,如泛化、關聯和依賴。它展示了一個外部使用者能夠觀察到的系統功能模型圖。

【用途】:幫助開發團隊以一種視覺化的方式理解系統的功能需求。

一、用例圖所包含的的元素

1. 參與者(Actor)——與應用程式或系統進行互動的使用者、組織或外部系統。用一個小人表示。

              

2. 用例(Use Case)——用例就是外部可見的系統功能,對系統提供的服務進行描述。用橢圓表示。

         

3. 子系統(Subsystem)——用來展示系統的一部分功能,這部分功能聯絡緊密。

二、用例圖所包含的的關係

  用例圖中涉及的關係有:關聯、泛化、包含、擴充套件。

  如下表所示:

  a. 關聯(Association)

  表示參與者與用例之間的通訊,任何一方都可傳送或接受訊息。

  【箭頭指向】:無箭頭,將參與者與用例相連線,指向訊息接收方

  b. 泛化(Inheritance)

  就是通常理解的繼承關係,子用例和父用例相似,但表現出更特別的行為;子用例將繼承父用例的所有結構、行為和關係。子用例可以使用父用例的一段行為,也可以過載它。父用例通常是抽象的。在實際應用中很少使用泛化關係,子用例中的特殊行為都可以作為父用例中的備選流存在。

  【箭頭指向】:指向父用例

  c. 包含(Include)

  包含關係用來把一個較複雜用例所表示的功能分解成較小的步驟。包含關係對典型的應用就是複用,也就是定義中說的情景。但是有時當某用例的事件流過於複雜時,為了簡化用例的描述,我們也可以把某一段事件流抽象成為一個被包含的用例;相反,用例劃分太細時,也可以抽象出一個基用例,來包含這些細顆粒的用例。這種情況類似於在過程設計語言中,將程式的某一段演算法封裝成一個子過程,然後再從主程式中呼叫這一子過程。

  例如:業務中,總是存在著維護某某資訊的功能,如果將它作為一個用例,那新增、修改以及刪除都要在用例詳述中描述,過於複雜;如果分成新增用例、修改用例和刪除用例,則劃分太細。這時包含關係可以用來理清關係。

  【箭頭指向】:指向分解出來的功能用例

  d. 擴充套件(Extend)

  擴充套件關係是指用例功能的延伸,相當於為基礎用例提供一個附加功能。將基用例中一段相對獨立並且可選的動作,用擴充套件(Extension)用例加以封裝,再讓它從基用例中宣告的擴充套件點(Extension Point)上進行擴充套件,從而使基用例行為更簡練和目標更集中。擴充套件用例為基用例新增新的行為。擴充套件用例可以訪問基用例的屬性,因此它能根據基用例中擴充套件點的當前狀態來判斷是否執行自己。但是擴充套件用例對基用例不可見。

對於一個擴充套件用例,可以在基用例上有幾個擴充套件點。

  【箭頭指向】:指向基礎用例

  e. 依賴(Dependency)

  以上4種關係,是UML定義的標準關係。但VS2010的用例模型圖中,新增了依賴關係,用帶箭頭的虛線表示,表示源用例依賴於目標用例。

  【箭頭指向】:指向被依賴項

  5. 專案(Artifact)

  用例圖雖然是用來幫助人們形象地理解功能需求,但卻沒多少人能夠通看懂它。很多時候跟使用者交流甚至用Excel都比用例圖強,VS2010中引入了“專案”這樣一個元素,以便讓開發人員能夠在用例圖中連結一個普通文件。

  用依賴關係把某個用例依賴到專案上:

  然後把專案->屬性的Hyperlink設定到你的文件上;

  這樣當你在用例圖上雙擊專案時,就會開啟相關聯的文件。

  6. 註釋(Comment)

  包含(include)、擴充套件(extend)、泛化(Inheritance) 的區別:

  條件性:泛化中的子用例和include中的被包含的用例會無條件發生,而extend中的延伸用例的發生是有條件的;

  直接性:泛化中的子用例和extend中的延伸用例為參與者提供直接服務,而include中被包含的用例為參與者提供間接服務。

  對extend而言,延伸用例並不包含基礎用例的內容,基礎用例也不包含延伸用例的內容。

  對Inheritance而言,子用例包含基礎用例的所有內容及其和其他用例或參與者之間的關係;

  ●泛化側重表示子用例間的互斥性;

  ●包含側重表示被包含用例對Actor提供服務的間接性;

  ●擴充套件側重表示擴充套件用例的觸發不定性;

  另外一點需要提及的是:泛化中的子用例和擴充套件中的擴充套件用例均可以作為基本用例事件的備選擇流而存在。

三、幾個用例圖示例

****************************************************************************

  以下為某線上購物系統的用例圖,對系統做出做了整體的描繪。

  (1)系統整體用例圖


(商品用例圖)



(購買資訊用例)


(使用者資料用例)

相關文章