新聞中心
本文和大家重點討論一下UML用例圖中include與extend的區(qū)別,include是指用例中的包含關(guān)系,通常發(fā)生在多個用例中,有可以提取出來的公共部分,而extend則恰好相反。下面請看本文詳細介紹。

創(chuàng)新互聯(lián)服務(wù)項目包括共和網(wǎng)站建設(shè)、共和網(wǎng)站制作、共和網(wǎng)頁制作以及共和網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,共和網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到共和省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
UML用例圖中include與extend的區(qū)別
最近上論壇,看到在爭論UseCase中include與extend的區(qū)別。其實這兩者是很容易區(qū)分的。
include是指用例中的包含關(guān)系,通常發(fā)生在多個用例中,有可以提取出來的公共部分(就象提取公因式一樣),例如UseCaseA中包括了a和b兩個流程,而UseCaseC中包含了c和b兩個流程。為了提高復(fù)用性,可以把b提取出來,形成另一個用例UseCaseB,此時,UseCaseAincludeUseCaseB(表現(xiàn)為一條指向UseCaseB的虛線,箭頭在UseCaseB側(cè)),UseCaseC也includeUseCaseB。因而,當(dāng)有include關(guān)系時,被include的用例通常會被兩個以上的其他用例include(否則就不需要重用,也就不需要提取出來了),UML用例圖如下:
在include關(guān)系中,“UseCaseA和UseCaseC知道UseCaseB的存在,而UseCaseB根本不知道有UseCaseA和UseCaseC);
extend則恰好相反。假設(shè)UseCaseA的功能描述為“發(fā)送一條通知”,可是,發(fā)送通知的方式可能有許多種,例如通過郵件發(fā)送、通過短信發(fā)送等。在需求分析階段,可能無法明確到底有多少種方式,在用例分析階段,UseCaseA需要留出擴展接口,然后把已知的發(fā)送方式作為擴展用例給出,例如UseCaseB是“通過短信發(fā)送”,而UseCaseC是“通過郵件發(fā)送”,此時,UseCaseB和UseCaseCextend了UseCaseA,表現(xiàn)為兩根虛線,箭頭指向UseCaseA,UML用例圖如下:
在extend關(guān)系中,UseCaseA不知道UseCaseB和UseCaseC的存在,但UseCaseB和UseCaseC卻是知道UseCaseA并且知道如何在UseCaseA中作擴展的。
另:在UML用例圖中,有時會看到兩個用例之間有依賴關(guān)系(表現(xiàn)為一條單向或雙向的實線),這是錯誤的,說明用例沒有提純。
也許有人會問“如果兩個用例之間,一個要調(diào)用另一個時,怎么辦?”(有可能是混淆了用例和模塊的關(guān)系),那么,首先要區(qū)分概念,用例就是用例,用例不是模塊,也不是組件(雖然一個用例能發(fā)展成為“一個或多個”模塊或組件);其次,從用例分析的角度來看,如果用例A確實要調(diào)用到用例B,那么,可以進一步分析:A是調(diào)用了B的所有流程呢,還是其中一部分流程?
(1)如果是調(diào)用了一部分,此時可以把B中的那部分流程提取出來,形成用例C,然后A和B都includeC;
(2)如果是調(diào)用了所有流程,那么,A直接includeB即可;
(3)如果A沒有調(diào)用B中的任何流程……faint,那還畫那條代表依賴的實線干嘛?
網(wǎng)頁名稱:解析UML用例圖中include與extend的區(qū)別
瀏覽地址:http://fisionsoft.com.cn/article/dhdcjig.html


咨詢
建站咨詢
