本文以實例的方式,展示了如何使用UML進行面向?qū)ο蟮姆治雠c設計。本文將假設讀者對UML、面向?qū)ο蟮阮I(lǐng)域的基本內(nèi)容已了然于胸,所以將不會過多闡述,而將重點放在應用過程上。本文的目的是通過一個完 " /> 在线看片a,色老汉视频,一级毛片在线不卡直接观看

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

例解基于UML的面向?qū)ο蠓治雠c設計

      摘要
      本文以實例的方式,展示了如何使用UML進行面向?qū)ο蟮姆治雠c設計。本文將假設讀者對UML、面向?qū)ο蟮阮I(lǐng)域的基本內(nèi)容已了然于胸,所以將不會過多闡述,而將重點放在應用過程上。本文的目的是通過一個完整的實例,展現(xiàn)基于UML的OOA&D過程的一個簡化模式,幫助朋友們更好的認識UML在OOA&D中起的作用。
      前言
      經(jīng)常聽到有朋友抱怨,說學了UML不知該怎么用,或者畫了UML卻覺得沒什么作用。其實,就UML本身來說,它只是一種交流工具,它作為一種標準化交流符號,在OOA&D過程中開發(fā)人員間甚至開發(fā)人員與客戶之間傳遞信息。另外,UML也可以看做是OO思想的一種表現(xiàn)形式,可以說“OO是神,而UML是型”。所以,想用好UML,扎實的OO思想基礎是必不可少的。然而,在UML應用到開發(fā)過程中時,還是有一定的模式可以遵循的。(注意,是模式而不是教條,我下面給出的流程只是一個啟發(fā)式過程,而不是說一定要遵循這個流程。)下面,我們通過一個CMS系統(tǒng)的分析設計實例,看看如何將UML應用到實際的開發(fā)中。
      1.從需求到業(yè)務用例圖
      OOA&D的第一步,就是了解用戶需求,并將其轉(zhuǎn)換為業(yè)務用例圖。我們的CMS系統(tǒng)需求非常簡單,大致課做如下描述:這個系統(tǒng)主要用來發(fā)布新聞,管理員只需要一個,登錄后可以在后臺發(fā)布新聞。任何人可以瀏覽新聞,瀏覽者可以注冊成為系統(tǒng)會員,注冊后可對新聞進行評論。管理員在后臺可以對新聞、評論、注冊會員進行管理,如修改、刪除等。
      通過以上需求描述,我們畫出如下的業(yè)務用例圖:
      這里要注意三點:
      1.業(yè)務用例是僅從系統(tǒng)業(yè)務角度關(guān)注的用例,而不是具體系統(tǒng)的用例。它描述的是“該實現(xiàn)什么業(yè)務”,而不是“系統(tǒng)該提供什么操作”。例如,在實際系統(tǒng)中,“登錄”肯定要作為一個用例,但是這是軟件系統(tǒng)中的操作,而用戶所關(guān)注的業(yè)務是不包含“登錄”的。
      2.業(yè)務用例僅包含客戶“感興趣”的內(nèi)容。
      3.業(yè)務用例所有的用例名應該讓客戶能看懂,如果某個用例的名字客戶看不懂什么意思,它也許就不適合作為業(yè)務用例。
      2.從業(yè)務用例圖到活動圖
      完成了業(yè)務用例圖后,我們要為每一個業(yè)務用例繪制一幅活動圖。活動圖描述了這個業(yè)務用例中,用戶可能會進行的操作序列。活動圖有個很重要的使命:從業(yè)務用例分析出系統(tǒng)用例。例如,下面是“新聞管理”的活動圖:
      可以看到,一個“新聞管理”這個業(yè)務用例,分解出N多系統(tǒng)操作。這里要特別注意這些操作,其中很多“活動”都很可能是一個系統(tǒng)用例(當然,不是每個都是)。例如,由這個活動圖可以看出,系統(tǒng)中至少要包含以下備選系統(tǒng)用例:登錄、注銷登錄、查看新聞列表、修改新聞、刪除新聞。
      這樣,將每個業(yè)務用例都繪制出相應的活動圖,再將其中的“活動”整合,就得出所有備選系統(tǒng)用例。
      3.從活動圖到系統(tǒng)用例圖
      找出所有的備選系統(tǒng)用例后,我們要對他們進行合并和篩選。合并就是將相同的用例合并成一個,篩選就是將不符合系統(tǒng)用例條件的備選用例去掉。
      一個系統(tǒng)用例應該是實際使用系統(tǒng)的用戶所進行的一個操作,例如,“查看新聞列表”就不能算一個系統(tǒng)用例,因為他只是某系統(tǒng)用例的一個序列項。
      最終我們得出的系統(tǒng)用例圖如下:
      4.從系統(tǒng)用例圖到用例規(guī)約
      得出系統(tǒng)用例圖后,我們應該對每一個系統(tǒng)用例給出用例規(guī)約。關(guān)于用例規(guī)約,沒有一個通用的格式,大家可以按照習慣的格式進行編寫。對用例規(guī)約唯一的要求就是“清晰易懂”。
      下面給出“登錄”這個系統(tǒng)用例的一個規(guī)約:
      5.繪制業(yè)務領(lǐng)域類圖
      完成了上面幾步,下面應該是繪制業(yè)務領(lǐng)域類圖了。所謂業(yè)務領(lǐng)域類圖要描述一下三點:
      1.系統(tǒng)中有哪些實體。
      2.這些實體能做什么操作。
      3.實體間的關(guān)系。
      這里要特別強調(diào):這里的實體不是Actor,而是Actor使用系統(tǒng)時使用的所調(diào)用的實體,是處在系統(tǒng)邊界之內(nèi)的實體。例如,管理員就沒有作為一個實體出現(xiàn)在這里,因為管理員處在系統(tǒng)邊界之外,它所有的工作都可以通過調(diào)用這三個類的方法完成。并且,這里的“注冊會員”實體也不是剛才用例圖中注冊會員這個Actor,而是作為一個系統(tǒng)內(nèi)的業(yè)務實體,供Actor們使用的。例如,其中的注冊功能是給注冊會員這個Actor使用,而移除則是給管理員這個Actor使用的。
      理解以上這段話非常重要,我經(jīng)常看到由于混淆了實體和Actor的關(guān)系而導致畫出的領(lǐng)域類圖不準確或職責分配不準確。
      大家可能還注意到,我們這里沒有給出每個實體的屬性。其實,在領(lǐng)域分析階段,實體的屬性并不重要,重要的是找出實體的操作。 
      6.繪制實現(xiàn)類圖
      以上這幾步,就是分析的過程。而下面的步驟就是設計了。
      設計沒有分析那么好描述,因為分析是“客戶面”,它只關(guān)心系統(tǒng)本身的功能和業(yè)務,而不關(guān)心任何和計算機有關(guān)的東西。但是,設計和平臺、語言、開發(fā)模型等內(nèi)容關(guān)系緊密,因而很難找出一個一致的過程。但是,一般在設計過程中實現(xiàn)類圖是要繪制的。
      實現(xiàn)類圖和領(lǐng)域類圖不一樣,它描述的是真正系統(tǒng)的靜態(tài)結(jié)構(gòu),是和最后的代碼完全一致的。因此,它和平臺關(guān)系密切,必須準確給出系統(tǒng)中的實體類、控制類、界面類、接口等元素以及其中的關(guān)系。因此,實現(xiàn)類圖是很復雜的,而且是平臺技術(shù)有關(guān)的。所以,我在這里不可能給出一個準確的實現(xiàn)類圖,不過為了描述,我還是給出一個簡化了的實現(xiàn)類圖,當然,它是不準確的,而只是從形式上給出實現(xiàn)類圖的樣子。
      我們假設這個系統(tǒng)建構(gòu)于.NET 3.5平臺上,并且使用ASP.NET MVC作為表示層,整體使用三層架構(gòu)。那么,用戶模塊體系的實現(xiàn)類圖大體是這樣子(不準確):
      7.繪制序列圖
      有了靜態(tài)結(jié)構(gòu),我們還要給出動態(tài)結(jié)構(gòu),這樣,才能看清系統(tǒng)間的類是如何交互的,從而有效幫助程序員進行編碼工作。
      上圖給出的是用戶登錄的序列圖。首先注冊會員作為Actor,調(diào)用UserController的Login方法啟動序列,然后序列按圖示步驟執(zhí)行。其中UserServices作為業(yè)務組件,首先調(diào)用數(shù)據(jù)訪問組件的GetByName確定用戶是否存在,如果存在,再調(diào)用GetByNameAndPassword確定輸入密碼是否是此用戶的密碼。從而完成業(yè)務功能。
      要注意,序列圖在實際中是很多的,幾乎每個類方法都配有相應的序列圖。
      8.后面的步驟
      在完成了上面的過程后,就可以進行編碼、調(diào)試、測試等工作了。但這些已經(jīng)超出了本文討論的范圍。
      總結(jié)
      本文簡要給出了使用UML進行OOA&D的過程。當然,由于示例較小,而且本人水平有限,所以給出的相關(guān)內(nèi)容可能不是很準確。而且軟件分析設計本來就不是一個固定模式的過程,隨著系統(tǒng)的不同整個過程會有變化。本文只是想起到一個拋磚引玉的作用,讓朋友們大致了解UML的使用流程。至于實際的分析設計,還需要深入的學習和實踐的積累。

it知識庫例解基于UML的面向?qū)ο蠓治雠c設計,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 天堂在线观看 | 一级做a爰久久毛片武则天 一级做a爰毛片 | 色偷偷影院| 黄色小视频在线免费观看 | 久久不雅视频 | 在线综合网 | sese欧美| 亚洲欧美激情在线 | 4hu永久影院在线四虎 | 亚洲国产成人在线 | 色鬼综合网 | 久久久久久网站 | www.天天干.com | 在线精品视频免费观看 | 亚洲视频1区 | 久久93精品国产91久久综合 | 狠狠成人 | 欧美三级成人观看 | 91高清在线视频 | 国产一级做a爰片久久毛片 国产一级做a爰片久久毛片99 | 国产在线观看麻豆91精品免费 | 久久国产一级毛片一区二区 | 亚洲黄色小说视频 | 成人精品第一区二区三区 | 国产色手机在线观看播放 | 日本一区免费在线 | 亚洲国产一区二区三区最新 | 91免费永久在线地址 | 久久久久久久久性潮 | 亚洲一区二区三区首页 | 国产精品一区二区三区免费 | 亚洲第一区二区快射影院 | 久久久xxxx | 亚洲精品成人久久久影院 | 国产福利毛片 | 亚洲香蕉网久久综合影院3p | 色综合手机在线 | 久久综合一| 丁香六月婷婷精品免费观看 | 久久精品1| 一级寡妇乱色毛片全场免费 |