成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

UML面向?qū)ο蠓治雠c設(shè)計(jì)解析

開發(fā) 架構(gòu)
UML是統(tǒng)一建模語言相信大家應(yīng)該有所了解,那么你對(duì)UML面向?qū)ο蠓治雠c設(shè)計(jì)是否了解,本文以實(shí)例的方式,展示了如果使用UML進(jìn)行面向?qū)ο蟮姆治雠c設(shè)計(jì)。

本節(jié)向大家向大家介紹一下UML面向?qū)ο蠓治雠c設(shè)計(jì),主要分布個(gè)步驟向大家介紹,相信通過本節(jié)的介紹你對(duì)UML面向?qū)ο蠓治雠c設(shè)計(jì)一定會(huì)有明確的認(rèn)識(shí)。下面是詳細(xì)介紹。

UML面向?qū)ο蠓治雠c設(shè)計(jì)

前言

就UML本身來說,它只是一種交流工具,它作為一種標(biāo)準(zhǔn)化交流符號(hào),在OOA&D過程中開發(fā)人員間甚至開發(fā)人員與客戶之間傳遞信息。另外,UML也可以看做是OO思想的一種表現(xiàn)形式,可以說“OO是神,而UML是型”。所以,想用好UML,扎實(shí)的OO思想基礎(chǔ)是必不可少的。然而,在UML應(yīng)用到開發(fā)過程中時(shí),還是有一定的模式可以遵循的。下面,我們通過一個(gè)CMS系統(tǒng)的分析設(shè)計(jì)實(shí)例,看看如何將UML應(yīng)用到實(shí)際的開發(fā)中。

1.從需求到業(yè)務(wù)用例圖

OOA&D的***步,就是了解用戶需求,并將其轉(zhuǎn)換為業(yè)務(wù)用例圖。我們的CMS系統(tǒng)需求非常簡(jiǎn)單,大致課做如下描述:這個(gè)系統(tǒng)主要用來發(fā)布新聞,管理員只需要一個(gè),登錄后可以在后臺(tái)發(fā)布新聞。任何人可以瀏覽新聞,瀏覽者可以注冊(cè)成為系統(tǒng)會(huì)員,注冊(cè)后可對(duì)新聞進(jìn)行評(píng)論。管理員在后臺(tái)可以對(duì)新聞、評(píng)論、注冊(cè)會(huì)員進(jìn)行管理,如修改、刪除等。
通過以上需求描述,我們畫出如下的業(yè)務(wù)用例圖。

這里要注意三點(diǎn):

1.業(yè)務(wù)用例是僅從系統(tǒng)業(yè)務(wù)角度關(guān)注的用例,而不是具體系統(tǒng)的用例。它描述的是“該實(shí)現(xiàn)什么業(yè)務(wù)”,而不是“系統(tǒng)該提供什么操作”。例如,在實(shí)際系統(tǒng)中,“登錄”肯定要作為一個(gè)用例,但是這是軟件系統(tǒng)中的操作,而用戶所關(guān)注的業(yè)務(wù)是不包含“登錄”的。
2.業(yè)務(wù)用例僅包含客戶“感興趣”的內(nèi)容。
3.業(yè)務(wù)用例所有的用例名應(yīng)該讓客戶能看懂,如果某個(gè)用例的名字客戶看不懂什么意思,它也許就不適合作為業(yè)務(wù)用例。

2.從業(yè)務(wù)用例圖到活動(dòng)圖

UML面向?qū)ο蠓治雠c設(shè)計(jì)完成了業(yè)務(wù)用例圖后,我們要為每一個(gè)業(yè)務(wù)用例繪制一幅活動(dòng)圖。活動(dòng)圖描述了這個(gè)業(yè)務(wù)用例中,用戶可能會(huì)進(jìn)行的操作序列。活動(dòng)圖有個(gè)很重要的使命:從業(yè)務(wù)用例分析出系統(tǒng)用例。例如,下面是“新聞管理”的活動(dòng)圖:

可以看到,一個(gè)“新聞管理”這個(gè)業(yè)務(wù)用例,分解出N多系統(tǒng)操作。這里要特別注意這些操作,其中很多“活動(dòng)”都很可能是一個(gè)系統(tǒng)用例(當(dāng)然,不是每個(gè)都是)。例如,由這個(gè)活動(dòng)圖可以看出,系統(tǒng)中至少要包含以下備選系統(tǒng)用例:登錄、注銷登錄、查看新聞列表、修改新聞、刪除新聞。
這樣,將每個(gè)業(yè)務(wù)用例都繪制出相應(yīng)的活動(dòng)圖,再將其中的“活動(dòng)”整合,就得出所有備選系統(tǒng)用例。

3.從活動(dòng)圖到系統(tǒng)用例圖

找出所有的備選系統(tǒng)用例后,我們要對(duì)他們進(jìn)行合并和篩選。合并就是將相同的用例合并成一個(gè),篩選就是將不符合系統(tǒng)用例條件的備選用例去掉。
一個(gè)系統(tǒng)用例應(yīng)該是實(shí)際使用系統(tǒng)的用戶所進(jìn)行的一個(gè)操作,例如,“查看新聞列表”就不能算一個(gè)系統(tǒng)用例,因?yàn)樗皇悄诚到y(tǒng)用例的一個(gè)序列項(xiàng)。
最終我們得出的系統(tǒng)用例圖如下:

4.從系統(tǒng)用例圖到用例規(guī)約

UML面向?qū)ο蠓治雠c設(shè)計(jì)得出系統(tǒng)用例圖后,我們應(yīng)該對(duì)每一個(gè)系統(tǒng)用例給出用例規(guī)約。關(guān)于用例規(guī)約,沒有一個(gè)通用的格式,大家可以按照習(xí)慣的格式進(jìn)行編寫。對(duì)用例規(guī)約唯一的要求就是“清晰易懂”。/p>
下面給出“登錄”這個(gè)系統(tǒng)用例的一個(gè)規(guī)約。

5.繪制業(yè)務(wù)領(lǐng)域類圖

完成了上面幾步,下面應(yīng)該是繪制業(yè)務(wù)領(lǐng)域類圖了。所謂業(yè)務(wù)領(lǐng)域類圖要描述一下三點(diǎn):

1.系統(tǒng)中有哪些實(shí)體。
2.這些實(shí)體能做什么操作。
3.實(shí)體間的關(guān)系。

這里要特別強(qiáng)調(diào):這里的實(shí)體不是Actor,而是Actor使用系統(tǒng)時(shí)使用的所調(diào)用的實(shí)體,是處在系統(tǒng)邊界之內(nèi)的實(shí)體。例如,管理員就沒有作為一個(gè)實(shí)體出現(xiàn)在這里,因?yàn)楣芾韱T處在系統(tǒng)邊界之外,它所有的工作都可以通過調(diào)用這三個(gè)類的方法完成。并且,這里的“注冊(cè)會(huì)員”實(shí)體也不是剛才用例圖中注冊(cè)會(huì)員這個(gè)Actor,而是作為一個(gè)系統(tǒng)內(nèi)的業(yè)務(wù)實(shí)體,供Actor們使用的。例如,其中的注冊(cè)功能是給注冊(cè)會(huì)員這個(gè)Actor使用,而移除則是給管理員這個(gè)Actor使用的。
理解以上這段話非常重要,我經(jīng)常看到由于混淆了實(shí)體和Actor的關(guān)系而導(dǎo)致畫出的領(lǐng)域類圖不準(zhǔn)確或職責(zé)分配不準(zhǔn)確。
大家可能還注意到,我們這里沒有給出每個(gè)實(shí)體的屬性。其實(shí),在領(lǐng)域分析階段,實(shí)體的屬性并不重要,重要的是找出實(shí)體的操作。

6.繪制實(shí)現(xiàn)類圖

以上這幾步,就是分析的過程。而下面的步驟就是UML面向?qū)ο蠓治雠c設(shè)計(jì)中的設(shè)計(jì)了。
設(shè)計(jì)沒有分析那么好描述,因?yàn)榉治鍪?ldquo;客戶面”,它只關(guān)心系統(tǒng)本身的功能和業(yè)務(wù),而不關(guān)心任何和計(jì)算機(jī)有關(guān)的東西。但是,設(shè)計(jì)和平臺(tái)、語言、開發(fā)模型等內(nèi)容關(guān)系緊密,因而很難找出一個(gè)一致的過程。但是,一般在設(shè)計(jì)過程中實(shí)現(xiàn)類圖是要繪制的。

實(shí)現(xiàn)類圖和領(lǐng)域類圖不一樣,它描述的是真正系統(tǒng)的靜態(tài)結(jié)構(gòu),是和***的代碼完全一致的。因此,它和平臺(tái)關(guān)系密切,必須準(zhǔn)確給出系統(tǒng)中的實(shí)體類、控制類、界面類、接口等元素以及其中的關(guān)系。因此,實(shí)現(xiàn)類圖是很復(fù)雜的,而且是平臺(tái)技術(shù)有關(guān)的。所以,我在這里不可能給出一個(gè)準(zhǔn)確的實(shí)現(xiàn)類圖,不過為了描述,我還是給出一個(gè)簡(jiǎn)化了的實(shí)現(xiàn)類圖,當(dāng)然,它是不準(zhǔn)確的,而只是從形式上給出實(shí)現(xiàn)類圖的樣子。
我們假設(shè)這個(gè)系統(tǒng)建構(gòu)于.NET3.5平臺(tái)上,并且使用ASP.NETMVC作為表示層,整體使用三層架構(gòu)。那么,用戶模塊體系的實(shí)現(xiàn)類圖大體是這樣子(不準(zhǔn)確):

7.繪制序列圖

有了靜態(tài)結(jié)構(gòu),我們還要給出動(dòng)態(tài)結(jié)構(gòu),這樣,才能看清系統(tǒng)間的類是如何交互的,從而有效幫助程序員進(jìn)行編碼工作。
要注意,序列圖在實(shí)際中是很多的,幾乎每個(gè)類方法都配有相應(yīng)的序列圖。

8.后面的步驟

UML面向?qū)ο蠓治雠c設(shè)計(jì),在完成了上面的過程后,就可以進(jìn)行編碼、調(diào)試、測(cè)試等工作了。但這些已經(jīng)超出了本文討論的范圍。


總結(jié)

本文簡(jiǎn)要給出了使用UML進(jìn)行OOA&D的過程。當(dāng)然,由于示例較小,而且本人水平有限,所以給出的相關(guān)內(nèi)容可能不是很準(zhǔn)確。而且軟件分析設(shè)計(jì)本來就不是一個(gè)固定模式的過程,隨著系統(tǒng)的不同整個(gè)過程會(huì)有變化。本文只是想起到一個(gè)拋磚引玉的作用,讓朋友們大致了解UML的使用流程。至于實(shí)際的分析設(shè)計(jì),還需要深入的學(xué)習(xí)和實(shí)踐的積累。

【編輯推薦】

  1. 用UML構(gòu)件進(jìn)行面向構(gòu)件分析與設(shè)計(jì)
  2. UML動(dòng)態(tài)建模機(jī)制專家解析
  3. 技術(shù)分享 UML面向?qū)ο蠓治黾捌浒ǖ膱D、建模步驟
  4. 解析UML面向?qū)ο蠓治雠c建模中交互圖
  5. 體驗(yàn)免費(fèi)UML建模工具


 

責(zé)任編輯:佚名 來源: csdn.net
相關(guān)推薦

2010-06-18 11:28:14

2009-06-26 13:38:46

UML面向?qū)ο?/a>

2010-06-17 09:22:48

UML面向?qū)ο蠓治雠c建

2010-07-08 13:35:39

UML面向?qū)ο?/a>

2010-07-06 17:21:08

UML面向?qū)ο?/a>

2022-08-26 08:35:59

對(duì)象設(shè)計(jì)底層

2010-07-08 10:47:42

UML面向?qū)ο?/a>

2010-06-17 11:27:11

UML構(gòu)件

2011-07-12 17:53:21

PHP

2010-06-13 17:56:49

UML面向?qū)ο?/a>

2010-07-09 09:51:26

UML面向?qū)ο?/a>

2023-03-10 07:43:50

UML圖OOA面向?qū)ο?/a>

2010-06-29 18:58:23

UML面向?qū)ο蠹夹g(shù)

2010-06-17 18:17:36

UML面向?qū)ο蠹夹g(shù)

2010-06-13 10:19:24

面向?qū)ο蠹夹g(shù)與UML

2010-06-18 10:34:05

UML面向?qū)ο?/a>

2020-10-10 11:03:24

面向?qū)ο?/a>編程語言開發(fā)

2010-06-18 15:55:47

UML建模

2010-06-17 11:12:53

UML構(gòu)件

2010-06-13 17:48:36

UML面向?qū)ο蠼?/a>
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产精品免费视频一区 | 日韩国产精品一区二区三区 | 成人在线观看黄 | 中文字幕亚洲一区二区三区 | 在线亚洲免费视频 | 97视频在线免费 | 2019天天操 | 国产乱码精品1区2区3区 | 天天干狠狠干 | 亚洲高清视频在线 | 激情一区 | 欧美精品一区二区三区在线 | 香蕉久久久久久 | 精品久久久久久亚洲精品 | 国产精品久久久久久久免费大片 | 久久久久久久久久久久久久久久久久久久 | 91黄在线观看 | 一区二区三区在线免费看 | 欧美一级二级三级视频 | 一区二区免费在线观看 | 欧美最猛黑人xxxⅹ 粉嫩一区二区三区四区公司1 | 亚洲综合大片69999 | www97影院 | 欧美一区二 | 国产精品黄色 | 在线观看黄色电影 | 久久久123 | 久久视频精品 | 中文字幕一区二区在线观看 | 激情五月婷婷丁香 | 欧美一区不卡 | 美日韩中文字幕 | 久久精品99久久 | 精品一区av | 在线观看日本高清二区 | 狠狠狠色丁香婷婷综合久久五月 | 日韩精品一区二区三区中文字幕 | 国产日韩精品视频 | 成人免费在线 | 91在线精品视频 | 久久99精品久久久久久 |