|
用例圖主要用來描述“用戶、需求、系統(tǒng)功能單元”之間的關(guān)系。它展示了一個外部用戶能夠觀察到的系統(tǒng)功能模型圖。
【用途】:幫助開發(fā)團(tuán)隊(duì)以一種可視化的方式理解系統(tǒng)的功能需求。
用例圖所包含的元素如下:
1. 參與者(Actor)
表示與您的應(yīng)用程序或系統(tǒng)進(jìn)行交互的用戶、組織或外部系統(tǒng)。用一個小人表示。
2. 用例(Use Case)
用例就是外部可見的系統(tǒng)功能,對系統(tǒng)提供的服務(wù)進(jìn)行描述。用橢圓表示。
3. 子系統(tǒng)(Subsystem)
用來展示系統(tǒng)的一部分功能,這部分功能聯(lián)系緊密。
4. 關(guān)系
用例圖中涉及的關(guān)系有:關(guān)聯(lián)、泛化、包含、擴(kuò)展。
如下表所示:
a. 關(guān)聯(lián)(Association)
表示參與者與用例之間的通信,任何一方都可發(fā)送或接受消息。
【箭頭指向】:指向消息接收方
b. 泛化(Inheritance)
就是通常理解的繼承關(guān)系,子用例和父用例相似,但表現(xiàn)出更特別的行為;子用例將繼承父用例的所有結(jié)構(gòu)、行為和關(guān)系。子用例可以使用父用例的一段行為,也可以重載它。父用例通常是抽象的。
【箭頭指向】:指向父用例
c. 包含(Include)
包含關(guān)系用來把一個較復(fù)雜用例所表示的功能分解成較小的步驟。
【箭頭指向】:指向分解出來的功能用例
d. 擴(kuò)展(Extend)
擴(kuò)展關(guān)系是指用例功能的延伸,相當(dāng)于為基礎(chǔ)用例提供一個附加功能。
【箭頭指向】:指向基礎(chǔ)用例
e. 依賴(Dependency)
以上4種關(guān)系,是UML定義的標(biāo)準(zhǔn)關(guān)系。但VS2010的用例模型圖中,添加了依賴關(guān)系,用帶箭頭的虛線表示,表示源用例依賴于目標(biāo)用例。
【箭頭指向】:指向被依賴項(xiàng)
5. 項(xiàng)目(Artifact)
用例圖雖然是用來幫助人們形象地理解功能需求,但卻沒多少人能夠通看懂它。很多時候跟用戶交流甚至用Excel都比用例圖強(qiáng),VS2010中引入了“項(xiàng)目”這樣一個元素,以便讓開發(fā)人員能夠在用例圖中鏈接一個普通文檔。
用依賴關(guān)系把某個用例依賴到項(xiàng)目上:
然后把項(xiàng)目-》屬性 的Hyperlink設(shè)置到你的文檔上;
這樣當(dāng)你在用例圖上雙擊項(xiàng)目時,就會打開相關(guān)聯(lián)的文檔。
6. 注釋(Comment)
包含(include)、擴(kuò)展(extend)、泛化(Inheritance) 的區(qū)別:
條件性:泛化中的子用例和include中的被包含的用例會無條件發(fā)生,而extend中的延伸用例的發(fā)生是有條件的;
直接性:泛化中的子用例和extend中的延伸用例為參與者提供直接服務(wù),而include中被包含的用例為參與者提供間接服務(wù)。
對extend而言,延伸用例并不包含基礎(chǔ)用例的內(nèi)容,基礎(chǔ)用例也不包含延伸用例的內(nèi)容。
對Inheritance而言,子用例包含基礎(chǔ)用例的所有內(nèi)容及其和其他用例或參與者之間的關(guān)系;
一個用例圖示例:
牢騷:
感覺用例圖還不成熟,并不能很好地表達(dá)系統(tǒng)的需求, 沒有UML背景的用戶幾乎不知道畫的是些什么。
其次,包含關(guān)系、擴(kuò)展關(guān)系的箭頭符號竟然是同樣的箭頭,僅靠上方寫個文字來加以區(qū)別,翻譯成其他語言的話,幾乎就不知道代表什么意思。擴(kuò)展關(guān)系的箭頭朝向也很難理解,為何要指向基用例,而不指向擴(kuò)展用例。
VS2010添加的“項(xiàng)目”元素,是個很好的創(chuàng)新,能夠在用例圖中關(guān)聯(lián)word, excel這些文檔。但為什么不把這些功能直接集成到用例里面,雙擊用例就彈出一份文檔豈不更容易理解,非要畫蛇添足地加一個元件,僅僅為了提供個鏈接功能。
用例描述表:
鑒于用列圖并不能清楚地表達(dá)功能需求,開發(fā)中大家通常用描述表來補(bǔ)充某些不易表達(dá)的用例,下圖的表給大家提供一個參考:
it知識庫:UML用例圖總結(jié),轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。