青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

mooyee's blog

C++博客 首頁(yè) 新隨筆 聯(lián)系 聚合 管理
  3 Posts :: 2 Stories :: 1 Comments :: 0 Trackbacks

從實(shí)例開(kāi)始談狀態(tài)圖的使用

                                                               2005119@gmail.com

                                                              v1.0 2006-03-15

 

摘要:在對(duì)“靚號(hào)租用”項(xiàng)目的重構(gòu)中,我通過(guò)狀態(tài)圖很好的理解了業(yè)務(wù)邏輯。由此進(jìn)一步歸納了狀態(tài)圖在開(kāi)發(fā)過(guò)程中的使用提示和技巧。

關(guān)鍵詞:UML,狀態(tài)圖,重構(gòu)

讀者水平:初級(jí)

 

引言

“靚號(hào)租用”是原無(wú)線技術(shù)部門開(kāi)發(fā)GLSMRPIDService中的一個(gè)部分,由于這部分存在已的功能缺陷,需要對(duì)之進(jìn)行適當(dāng)?shù)男薷模ㄟ^(guò)這種方式來(lái)使功能得到完善并使版本得到演進(jìn)。我先給出當(dāng)前需求,對(duì)對(duì)象“靚號(hào)”的狀態(tài)圖。

 

按圖說(shuō)圖圖(1)描述了對(duì)象“靚號(hào)”在其生命期中的幾個(gè)狀態(tài),“靚號(hào)”能被鎖定,被鎖定的“靚號(hào)”不能被其它用戶再鎖定。被鎖定的靚號(hào)如果在15分鐘內(nèi)沒(méi)被用戶租用,則還回到初始狀態(tài),可以再被(其他)用戶鎖定。被鎖定的“靚號(hào)”可以被租用,租用到期后能被系統(tǒng)預(yù)留(即為先前的用戶保護(hù)起來(lái)),預(yù)留一個(gè)月后如用戶未續(xù)租,則此“靚號(hào)”可以被其他人鎖定或租用。在租用狀態(tài)下的“靚號(hào)”,如果被同一用戶累積租用超過(guò)半年,則可以買斷。被買斷后,此“靚號(hào)”變成普通號(hào)。

概念

很遺憾,原設(shè)計(jì)由于所面對(duì)的問(wèn)題領(lǐng)域規(guī)模小,所以并沒(méi)有采用OOD/OOP的方式,所以看不到 CCoolIdentity這樣的實(shí)體類,但由于問(wèn)題領(lǐng)域所處理的對(duì)象即為“靚號(hào)”,因此,這里先引入這個(gè)類。這里,插入狀態(tài)圖使用的第一個(gè)準(zhǔn)則:

準(zhǔn)則1: 狀態(tài)圖只對(duì)單一對(duì)象的復(fù)雜行為進(jìn)行模建。這里的對(duì)象指類、角色、子系統(tǒng)、或組件。

因此,狀態(tài)圖并不為多個(gè)對(duì)象之間的行為建模。多個(gè)對(duì)象之間的行為建模參考“活動(dòng)圖”,“時(shí)序圖”,對(duì)象之間的關(guān)系參考“類圖”,“對(duì)象圖”以及參考設(shè)計(jì)模式(設(shè)計(jì)模式通常用UMLBooch圖表示類之間的關(guān)系, BoochUML的前身)。現(xiàn)在我們給出狀態(tài)圖的定義。

    狀態(tài)圖,全稱為狀態(tài)機(jī)視圖(state machine view),通過(guò)對(duì)每個(gè)類的生個(gè)對(duì)象形字的生命期建模,描述了對(duì)象在時(shí)間上的動(dòng)態(tài)行為。狀態(tài)圖用于對(duì)模型元素的動(dòng)態(tài)行為進(jìn)行建模,更具體地說(shuō),就是對(duì)系統(tǒng)行為中受事件驅(qū)動(dòng)的方面進(jìn)行建模。

  

  狀態(tài)圖由狀態(tài)組成,各狀態(tài)由轉(zhuǎn)移鏈接在一起。狀態(tài)是對(duì)象執(zhí)行某項(xiàng)活動(dòng)或等待某個(gè)事件時(shí)的條件。轉(zhuǎn)移是兩個(gè)狀態(tài)之間的關(guān)系,它由某個(gè)事件觸發(fā),然后執(zhí)行特定的操作或評(píng)估并導(dǎo)致特定的結(jié)束狀態(tài)。圖 (2) 描繪了狀態(tài)圖的各種元素。

圖2md_state1.gif

態(tài)是對(duì)象執(zhí)行某項(xiàng)活動(dòng)或等待某個(gè)事件時(shí)的條件。對(duì)象可能會(huì)在有限的時(shí)間長(zhǎng)度內(nèi)保持某一狀態(tài)。狀態(tài)具有以下幾項(xiàng)特征:

名稱

將一個(gè)狀態(tài)與其他狀態(tài)區(qū)分開(kāi)來(lái)的文本字符串;狀態(tài)也可能是匿名的,這表示它沒(méi)有名稱。

進(jìn)入/退出操作

在進(jìn)入和退出狀態(tài)時(shí)所執(zhí)行的操作。

內(nèi)部轉(zhuǎn)移

在不使?fàn)顟B(tài)發(fā)生變更的情況下進(jìn)行的轉(zhuǎn)移。

子狀態(tài)

狀態(tài)的嵌套結(jié)構(gòu),包括不相連的(依次處于活動(dòng)狀態(tài)的)或并行的(同時(shí)處于活動(dòng)狀態(tài)的)子狀態(tài)。

延遲的事件

未在該狀態(tài)中處理但被延遲處理(即列隊(duì)等待由另一個(gè)狀態(tài)中的對(duì)象來(lái)處理)的一系列事件。

如圖 (2) 所示,可以為對(duì)象的狀態(tài)圖定義兩種特殊的狀態(tài)。初始狀態(tài)指示狀態(tài)圖或子狀態(tài)的默認(rèn)起始位置。

何時(shí)需要狀態(tài)圖

在實(shí)際的項(xiàng)目開(kāi)發(fā)中,并不是對(duì)每一個(gè)類都畫狀態(tài)圖。何時(shí)需要狀態(tài)圖,我們可以采用下面的原則來(lái)確定:

敏捷建模( AM) ( Ambler 2002)的原則--最大化項(xiàng)目干系人的投資--建議你只有當(dāng)模型能夠提供正面價(jià)值的時(shí)候才創(chuàng)建模型。 如果一個(gè)實(shí)體,比如一個(gè)類或組件,表示的行為的順序和當(dāng)前的狀態(tài)無(wú)關(guān),那么畫一個(gè)UML狀態(tài)圖可能是沒(méi)有什么用處的。例如一個(gè)CLogFile類就很簡(jiǎn)單,表示了那些你將會(huì)在系統(tǒng)中記錄一操作的數(shù)據(jù),因此一個(gè)UML狀態(tài)圖就沒(méi)有任何相關(guān)之處。而“靚號(hào)”這類對(duì)象就經(jīng)比較的復(fù)雜。

提示與技巧

l         當(dāng)給定一項(xiàng)選擇時(shí),要使用狀態(tài)圖的可視語(yǔ)義,而不要寫出詳細(xì)的轉(zhuǎn)移代碼。例如,不要用幾個(gè)信號(hào)觸發(fā)一個(gè)轉(zhuǎn)移,然后使用詳細(xì)代碼來(lái)管理以不同的方式依賴于信號(hào)的控制流。應(yīng)使用由單獨(dú)的信號(hào)來(lái)觸發(fā)的單獨(dú)轉(zhuǎn)移。在隱藏了附加行為的轉(zhuǎn)移代碼中,要避免使用條件邏輯。

l         根據(jù)在狀態(tài)期間等待的事件或正在發(fā)生的事件來(lái)命名狀態(tài)。記住,狀態(tài)不是“時(shí)間點(diǎn)”;它是狀態(tài)圖等待某個(gè)事件發(fā)生的時(shí)間段。例如,“waitingForEnd”這一名稱比“end”更好;“timingSomeActivity”比“timeout”更好。不要讓狀態(tài)的名稱看起來(lái)象是操作名。

l         在一個(gè)狀態(tài)圖內(nèi)唯一地命名所有狀態(tài)和轉(zhuǎn)移;這將便于進(jìn)行源級(jí)別的調(diào)試。

l         謹(jǐn)慎使用狀態(tài)變量;不要在創(chuàng)建新?tīng)顟B(tài)時(shí)使用它們。如果狀態(tài)不多,很少帶有或不帶有依賴于狀態(tài)的行為,并且很少有或根本沒(méi)有可能與包含狀態(tài)圖的封裝體并行或獨(dú)立的行為,就可以使用狀態(tài)變量。如果有復(fù)雜的、依賴于狀態(tài)的潛在并行行為,或者如果必須處理的事件可能來(lái)自于包含狀態(tài)圖的封裝體之外,則應(yīng)考慮使用構(gòu)件封裝體。

l         如果單個(gè)圖中的狀態(tài)超過(guò) 5 * 2 個(gè),就應(yīng)考慮使用子狀態(tài)。在這里可以應(yīng)用我們的常識(shí):在一個(gè)非常規(guī)則的模式中可以有十個(gè)狀態(tài),但如果兩個(gè)狀態(tài)之間具有四十個(gè)轉(zhuǎn)移,顯然就需要重新考慮了。務(wù)必要使?fàn)顟B(tài)圖易于理解。

l         使用觸發(fā)事件的事件和/或在轉(zhuǎn)移期間發(fā)生的事件為轉(zhuǎn)移命名。選擇更加易于理解的名稱。

l         當(dāng)您看見(jiàn)一個(gè)選擇點(diǎn)時(shí),應(yīng)考慮是否可以將作出該選擇的職責(zé)委托給另一個(gè)構(gòu)件,以便將其作為一組將不同的信號(hào)提供給封裝體遵照?qǐng)?zhí)行(例如,代替對(duì)消息->數(shù)據(jù) > x 的選擇),并考慮是否可以讓發(fā)送方或另一中間主角來(lái)作出決定,然后通過(guò)在信號(hào)名稱中明確顯示該決定的方式發(fā)送信號(hào)(例如,使用名為 isFull isEmpty 的信號(hào),而不是以值命名信號(hào)并檢查消息數(shù)據(jù))。

l         為在選擇點(diǎn)中回答的問(wèn)題指定描述性的名稱,例如“isThereStillLife”或“isItTimeToComplain”。

l         在任何給定的封裝體中,盡量使選擇點(diǎn)名稱保持唯一(其原因與轉(zhuǎn)移名稱需保持唯一相同)。

l         轉(zhuǎn)移的代碼段是否太長(zhǎng)?是否應(yīng)使用函數(shù)來(lái)代替它們,是否將常用代碼段記錄為函數(shù)?轉(zhuǎn)移應(yīng)該類似于高層的偽代碼,并且應(yīng)當(dāng)遵循與 C++ 函數(shù)相同或更嚴(yán)格的長(zhǎng)度規(guī)則。例如,代碼超過(guò) 25 行的轉(zhuǎn)移可被認(rèn)為是過(guò)長(zhǎng)。

l         應(yīng)根據(jù)函數(shù)執(zhí)行的操作來(lái)命名函數(shù)。

l         要特別注意進(jìn)入和退出操作:在進(jìn)行更改后忘記更改相應(yīng)進(jìn)入和退出操作的情況尤其容易發(fā)生。

l         退出操作可用于提供安全性功能,例如,從“heaterOn”狀態(tài)中的退出操作將關(guān)閉加熱器,在這里,操作被用來(lái)強(qiáng)制執(zhí)行一個(gè)斷言語(yǔ)句。

l         通常,除非狀態(tài)圖是抽象的并且將由包含元素的子類來(lái)進(jìn)行改進(jìn),否則子狀態(tài)應(yīng)包含兩個(gè)或更多個(gè)狀態(tài)。

l         應(yīng)該用選擇點(diǎn)來(lái)代替操作或轉(zhuǎn)移中的條件邏輯。選擇點(diǎn)容易被看到,而代碼中的條件邏輯則是不可見(jiàn)的,很容易被忽略。

l         避免使用警戒條件。

n         如果事件觸發(fā)了幾個(gè)轉(zhuǎn)移,將無(wú)法控制首先對(duì)哪個(gè)警戒條件求值。這會(huì)產(chǎn)生無(wú)法預(yù)料的結(jié)果。

n         可能有多個(gè)警戒條件為“True”,但隨后只能有一個(gè)轉(zhuǎn)移。所選擇的路徑是無(wú)法預(yù)料的。

n         警戒條件是不可見(jiàn)的;要“看見(jiàn)”它們的出現(xiàn)更是困難。

n         避免使用類似流程圖的狀態(tài)圖。

u       這可能表示您試圖對(duì)并不實(shí)際存在的抽象概念進(jìn)行建模,例如:

u       使用一個(gè)封裝體來(lái)對(duì)最適合于數(shù)據(jù)類的行為進(jìn)行建模,或

n         通過(guò)使用緊密耦合的數(shù)據(jù)類和封裝體類來(lái)對(duì)數(shù)據(jù)類建模(例如,數(shù)據(jù)類用于向四周傳遞類型信息,但封裝體類包含了應(yīng)與數(shù)據(jù)類相關(guān)聯(lián)的大部分?jǐn)?shù)據(jù))。

u       狀態(tài)圖的這種錯(cuò)誤用法可以通過(guò)以下故障現(xiàn)象來(lái)識(shí)別:

u       被發(fā)送給“自己”的消息,主要是為了重復(fù)使用代碼

u       幾乎沒(méi)有狀態(tài),但有很多選擇點(diǎn)

u       在某些情況下沒(méi)有循環(huán)的狀態(tài)圖。在流程控制應(yīng)用程序中,或者在試圖控制一個(gè)事件序列時(shí),這樣的狀態(tài)圖是有效的;如果它們?cè)诜治鲞^(guò)程中出現(xiàn),則表示狀態(tài)圖已退化為流程圖。

n         當(dāng)發(fā)現(xiàn)問(wèn)題時(shí),應(yīng)采取以下措施:

u       考慮將封裝體分解為職責(zé)更明確的小單元,

u       將更多的行為轉(zhuǎn)移到與有問(wèn)題的封裝體相關(guān)聯(lián)的數(shù)據(jù)類中。

u       將更多的行為轉(zhuǎn)移到封裝體類函數(shù)中。

u       制作更有意義的信號(hào),以避免對(duì)數(shù)據(jù)的依賴。

l         避免"黑洞"狀態(tài)。

n         黑洞狀態(tài)是那種只有變換進(jìn)來(lái)但沒(méi)有任何變換發(fā)出的狀態(tài),這種情況要么由于該狀態(tài)是一個(gè)最終狀態(tài),要么就是你已經(jīng)錯(cuò)過(guò)了一個(gè)或多個(gè)變換變換。

l         避免"奇跡"狀態(tài)。

n         奇跡狀態(tài)是那種只有變換發(fā)出但沒(méi)有任何變換進(jìn)來(lái)的狀態(tài),這種情況要么由于該狀態(tài)是一個(gè)起點(diǎn),要么就是你已經(jīng)錯(cuò)過(guò)了一個(gè)或多個(gè)變換變換。

參考文獻(xiàn)

       UML用戶手冊(cè)》

     Rational Unified Process

     其它網(wǎng)絡(luò)資源

 

posted on 2006-03-15 17:23 stone 閱讀(4970) 評(píng)論(1)  編輯 收藏 引用 所屬分類: UML,RUP,設(shè)計(jì)模式

Feedback

# re: 從實(shí)例開(kāi)始談狀態(tài)圖的使用 2009-01-20 21:18 p_cy
好  回復(fù)  更多評(píng)論
  


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久亚洲捆绑美女| 欧美午夜在线视频| 国产精品日韩在线播放| 一本久道久久综合中文字幕| 亚洲电影免费| 久久久久中文| 一本色道久久精品| 在线综合欧美| 国产视频在线观看一区二区三区| 性欧美超级视频| 久久蜜桃精品| 亚洲免费人成在线视频观看| 在线亚洲欧美专区二区| 国产欧美高清| 亚洲人成在线播放网站岛国| 国产精品成人一区二区| 久久人91精品久久久久久不卡| 你懂的视频欧美| 欧美激情亚洲| 久久久久99精品国产片| 欧美福利电影在线观看| 亚洲欧美国产高清| 久久一二三国产| 亚洲欧美日韩中文播放| 欧美成人一区二免费视频软件| 性欧美xxxx视频在线观看| 免费在线欧美视频| 久久久亚洲欧洲日产国码αv | 免费毛片一区二区三区久久久| 亚洲一区在线免费| 欧美日韩另类字幕中文| 欧美久久99| 日韩亚洲精品视频| 9l国产精品久久久久麻豆| 久久久www| 久久一区国产| 黄色亚洲在线| 麻豆av福利av久久av| 免费观看成人www动漫视频| 国产一区二区三区四区在线观看| 亚洲一区二区三区乱码aⅴ蜜桃女| 午夜国产精品视频| 欧美三日本三级三级在线播放| 亚洲国产成人久久| 亚洲第一在线综合在线| 久久久久久午夜| 久久综合一区二区| 91久久久久久久久| 欧美精品久久久久久久免费观看| 亚洲人成精品久久久久| 香港久久久电影| 亚洲日产国产精品| 午夜激情一区| 亚洲精品久久7777| 久久精品人人做人人综合| 极品尤物av久久免费看| 国产精品99久久久久久白浆小说| 欧美与黑人午夜性猛交久久久| 国产视频一区在线观看| 午夜在线精品| 亚洲欧美成人| 最新亚洲激情| 欧美日韩亚洲网| 久久电影一区| 亚洲视频碰碰| 欧美一区二区三区在线| 久久久久久久精| 麻豆精品精品国产自在97香蕉| 毛片av中文字幕一区二区| 99在线热播精品免费99热| 农夫在线精品视频免费观看| 狠狠色丁香久久婷婷综合_中| 亚洲欧美制服另类日韩| 欧美一区二区三区精品 | 亚洲一区尤物| 国产精品视频xxxx| 亚洲午夜久久久久久尤物 | 亚洲影院免费观看| 国产精品一区2区| 欧美一区二区三区免费观看| 久久久精品性| 亚洲国产欧美不卡在线观看| 嫩草国产精品入口| 宅男66日本亚洲欧美视频| 欧美一区二区三区在线视频 | 亚洲国产精品免费| 欧美精品www在线观看| 一本色道久久综合| 欧美中文日韩| 亚洲国产一区二区精品专区| 欧美日韩系列| 欧美中文在线观看| 亚洲国产美女| 香蕉成人啪国产精品视频综合网| 国产亚洲精品久久久久动| 久久五月天婷婷| 99精品国产在热久久婷婷| 欧美在线播放高清精品| 亚洲国产成人不卡| 欧美视频网址| 久久亚洲精品欧美| 日韩一级黄色片| 久久久亚洲国产美女国产盗摄| 亚洲麻豆国产自偷在线| 国产日本欧美一区二区| 宅男噜噜噜66国产日韩在线观看| 一本色道久久加勒比88综合| 午夜精品理论片| 亚洲第一中文字幕在线观看| 欧美日韩一区二区视频在线观看 | 午夜久久tv| 亚洲欧洲一区二区三区在线观看 | 免费成人黄色片| 亚洲男女毛片无遮挡| 亚洲国产成人高清精品| 国产美女精品| 欧美日韩情趣电影| 久久一区二区三区av| 亚洲欧美日韩综合aⅴ视频| 亚洲国产精品一区二区www| 久久疯狂做爰流白浆xx| 中国成人黄色视屏| 亚洲黑丝在线| 国产自产精品| 国产精品夜色7777狼人| 欧美日韩精品免费看| 蜜臀av国产精品久久久久| 久久www成人_看片免费不卡| 亚洲桃色在线一区| 99热在线精品观看| 亚洲欧洲在线一区| 亚洲电影在线看| 蘑菇福利视频一区播放| 久久精品国产精品亚洲精品| 午夜视频在线观看一区二区| 亚洲一区黄色| 中国日韩欧美久久久久久久久| 91久久久久久久久| 亚洲区免费影片| 亚洲国产精品电影在线观看| 亚洲成人中文| 最新日韩欧美| 日韩一二三在线视频播| 亚洲美女av电影| 99re热这里只有精品免费视频| 亚洲精品一区二区三区不| 亚洲欧洲日本一区二区三区| 亚洲二区三区四区| 亚洲人www| 99精品免费视频| 国产精品99久久久久久久vr | 亚洲第一精品久久忘忧草社区| 在线精品福利| 亚洲伦伦在线| 亚洲免费视频一区二区| 性视频1819p久久| 久久精品国产亚洲精品| 久久综合电影一区| 欧美韩日一区| 日韩视频二区| 亚洲欧美www| 久久久久国产精品厨房| 六月婷婷久久| 欧美性猛交xxxx免费看久久久 | 国内自拍视频一区二区三区| 韩国三级在线一区| 亚洲人成人99网站| 亚洲专区欧美专区| 久久综合久久综合九色| 亚洲激情视频| 亚洲男同1069视频| 久久夜色精品国产噜噜av| 欧美日韩成人综合天天影院| 国产精品久久久久毛片软件| 亚洲国产精品一区在线观看不卡 | 亚洲一区bb| 久久久久久色| 欧美新色视频| 亚洲动漫精品| 亚洲欧美色婷婷| 牛牛精品成人免费视频| 99视频精品在线| 久久精品亚洲| 欧美性一二三区| 亚洲第一久久影院| 性欧美大战久久久久久久免费观看 | 欧美精品激情blacked18| 国产日韩1区| 99re成人精品视频| 六月婷婷一区| 亚洲午夜一区二区| 欧美承认网站| 激情一区二区三区| 午夜影视日本亚洲欧洲精品| 欧美sm视频| 欧美一区在线直播| 欧美亚洲成人精品| 99xxxx成人网| 欧美国产视频日韩| 欧美在线国产|