飛艷小屋

          程序--人生--哲學(xué)___________________歡迎艷兒的加入

          BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
            52 Posts :: 175 Stories :: 107 Comments :: 0 Trackbacks
          什么是域建模呢?我們設(shè)計一個系統(tǒng),總是希望它能解決一些問題,這些問題總是映射到現(xiàn)實問題和概念。很明顯我們的系統(tǒng)依賴于這些問題,對這些問題進行歸納、分析的過程就是域建模(這個域,指的就是問題域)。
          2005-9-15]
          連載:ICONIX 統(tǒng)一建模起步之三 域建模之一 發(fā)現(xiàn)類
            歡迎大家回到我的連載,從這一期開始,我們正式進入ICONIX的世界。閑話少說,進入正題。
            什么是域建模呢?我們設(shè)計一個系統(tǒng),總是希望它能解決一些問題,這些問題總是映射到現(xiàn)實問題和概念。很明顯我們的系統(tǒng)依賴于這些問題,對這些問題進行歸納、分析的過程就是域建模(這個域,指的就是問題域)。
            好了,講理論大家要昏昏欲睡,我這個小小的連載也沒辦法把所有的概念說的一清二楚,要是有興趣的話可以打電話跟我暢談(前提是不許打手機),現(xiàn)在我來用一個實際的例子講述域建模。
            用個比較簡單的例子吧,本來昨天我是想用HelloWorld來的,可是它實在太簡單了,不能說明問題,考慮再三,我使用一個猜數(shù)游戲來說明問題。這個游戲相信學(xué)過編程語言的都應(yīng)該很熟悉了:輸入一個數(shù),如果猜中了顯示“你好棒啊”然后結(jié)束,如果不對,系統(tǒng)告訴你是太大還是太小,然后重新讓你輸入,直到猜中為止。
            現(xiàn)在請拿一張白紙,我們開始歸納問題。
          +--------------------------------------------+
          |  系統(tǒng)應(yīng)該準備一個正確答案        |
          |                      |
          |  玩家可以輸入一個答案          |
          |                      |
          |  系統(tǒng)應(yīng)該比較玩家輸入的答案和正確答案  |
          |                      |
          |  系統(tǒng)應(yīng)該顯示玩家每次輸入的結(jié)果     |
          +--------------------------------------------+
            遺憾我這個例子還是太過于簡單,不過簡單也有簡單的好處,從這個簡單的例子可以看出歸納問題的基本要點。
            第一是不要涉及內(nèi)部的流程,別出現(xiàn)“如果輸入不正確,就怎么怎么樣”的句子,這些并不是正確的問題,正確的問題必須明確的,清晰的,如果可能的話全部按照“什么可以干什么”的格式來寫。
            第二是不要一開始就進入細節(jié)(抱歉,我這個例子例外,它實在是太簡單了),包涵太多細節(jié)的問題將會是一個長長的清單,這種清單根本沒什么用。盡量從最高一層分析,但也不要簡單到“用戶可以玩游戲”這種籠統(tǒng)的問題??傊粋€原則是全面、清晰、明確。要做好問題域分析完全取決于設(shè)計師的水平與能力,這就不是可以簡單的看看書能達到的了。
            好了,現(xiàn)在我們有了一個系統(tǒng)問題域的清單,可以進行下一步工作:發(fā)現(xiàn)類。
            把問題清單中的名詞都提出來,得到一個名詞列表,這就是類的來源(不過不忙,這只是初步過程)
          +----------------+
          |  系統(tǒng)    |
          |  玩家    |
          |  正確答案  |
          |  答案    |
          |  游戲結(jié)果  |
          +----------------+
            不是所有的名詞都能作為類的,接下來需要進行篩選。
            玩家是參與者,應(yīng)該放到用例圖上去
            系統(tǒng)太籠統(tǒng),不能成為一個對象的名稱
            答案和正確答案容易混淆,但稱為輸入答案又容易被誤解成一個動作,干脆叫做玩家答案
            結(jié)果不明確,察看前面的需求,應(yīng)該分解成錯誤信息和完成信息
            篩選完畢后,得到下面一個名詞列表:
          +----------------+
          |  正確答案  |
          |  玩家答案  |
          |  錯誤信息  |
          |  完成信息  |
          +----------------+
            這個列表缺少了系統(tǒng),顯得太單薄,回過頭再仔細察看需求,應(yīng)該引入一個游戲引擎,由它來充當調(diào)度者。
          +----------------+
          |  游戲引擎  |
          |  正確答案  |
          |  玩家答案  |
          |  錯誤信息  |
          |  完成信息  |
          +----------------+
            同時修改前面的問題域,現(xiàn)在系統(tǒng)已經(jīng)明確是一個游戲引擎。這種替換當然是一種理想情況,通常都會發(fā)生分解和關(guān)聯(lián),那時候需要擴充問題域,有時候還需要建立新的問題域。
          +--------------------------------------------+
          |  游戲引擎應(yīng)該準備一個正確答案      |
          |                      |
          |  玩家可以輸入一個答案          |
          |                      |
          |  游戲引擎應(yīng)該比較玩家答案和正確答案   |
          |                      |
          |  游戲引擎應(yīng)該顯示玩家每次輸入的結(jié)果   |
          +--------------------------------------------+
            現(xiàn)在可以用Rose來制作Class Diagram了,同時可以用RAD工具來搞一個小小的GUI來看看效果,發(fā)現(xiàn)類工作到此告一段落。不過問題域分析還沒完,類與類之間的關(guān)系還沒有歸納,當然,那是下一段要講的事情了。

          posted on 2006-06-02 11:18 天外飛仙 閱讀(429) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 毕节市| 渭源县| 新民市| 修文县| 年辖:市辖区| 八宿县| 文成县| 彭州市| 察雅县| 三河市| 微山县| 精河县| 白山市| 宁南县| 萨嘎县| 通江县| 义马市| 博兴县| 鄂伦春自治旗| 历史| 岐山县| 荔波县| 崇左市| 漳州市| 宿松县| 红原县| 庆安县| 双柏县| 岳西县| 新竹县| 平利县| 六盘水市| 邵东县| 介休市| 宜昌市| 寻乌县| 亳州市| 繁昌县| 苏尼特左旗| 满城县| 恩施市|