• <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>
            隨筆 - 119  文章 - 290  trackbacks - 0

            博客搬家了哦,請移步
            叫我abc

            常用鏈接

            留言簿(12)

            隨筆分類

            我的博客

            搜索

            •  

            積分與排名

            • 積分 - 304354
            • 排名 - 84

            最新評論

            閱讀排行榜

            最近寫課程需求的時候,掌握了一些東西。盡量把膠合物集中起來,放在一個模塊中,而不是零碎的分布在各處,會讓代碼看起來不那么刺眼。
            舉手頭上的project。
            有4個類,分別是CPlayer,IMonster,IDevice,ITerrainPortion。這4個類代表了整個游戲邏輯(規則),邏輯的執行通過兩兩相交碰撞來驅動。
            在最初的設計中,每一個類都有接口對待其余3個類,也就是每一個類都知道規則的一部分。比如代碼:
            CPlayer::collid(UserDefineObj?&obj)
            {
            switch?(obj.getType())
            {
            case?MONSTER:
            IMonster?
            *pm?=?dynamic_castIMonster*>(&obj);
            do?some?work?1;
            break;
            case?DEVICE:

            case??
            }

            }
            根據類型來向下轉換是很煩人的,并且不同類型所用到的邏輯代碼也大有不同。雖然說很想提供那么一個最高接口,給出統一的部署,省卻轉換,但是統一的部署首先是相當難做到,并且使得每個類的的有些行為的語意有些畸形。同時,統一部署之下,只是讓接口看起來統一,但接口之下的實現確會更復雜。(完全說不明白)
            按照這種分布式的膠合,增加了各個類型之間的耦合,因為每個類型都要區別其他類型,并執行恰當的代碼,就先要知道其他類型的存在。
            后來想到的集中膠合,由一個類,了解所有存在的類型,以及各個類型之間的規則,然后在實現中,根據兩兩的類型選擇合適的處理函數,驅動邏輯。而其他類型本身,只要提供該類驅動邏輯時需要的方法就夠了。
            。。。。
            posted on 2006-09-17 19:58 LOGOS 閱讀(657) 評論(4)  編輯 收藏 引用

            FeedBack:
            # re: 雜亂的設計念頭 2006-09-17 21:08 萬連文
            如果基于COM做,如果想實現一個頂層對象以便查詢所有需要接口,可以參考實現IServiceProvider接口進行服務派送  回復  更多評論
              
            # re: 雜亂的設計念頭 2006-09-19 12:48 lunny
            除了main中,其它的類應該都只知道接口  回復  更多評論
              
            # re: 雜亂的設計念頭 2006-09-20 14:20 Wei
            Try *Abstract Factory* or "Strategy" patterns  回復  更多評論
              
            # re: 雜亂的設計念頭 2006-09-20 17:10 LOGOS
            其實最終確定下來的念頭是,要做一個collide AI模塊,把所有麻煩的東西集中到一起。  回復  更多評論
              
            99久久婷婷国产一区二区| 久久久久亚洲精品天堂久久久久久| 丰满少妇人妻久久久久久4| 亚洲国产精品久久| 久久婷婷色综合一区二区| 人妻无码精品久久亚瑟影视| 2021国产精品久久精品| 99久久久精品免费观看国产| 国产精品日韩欧美久久综合| 久久人人爽人人爽人人片av麻烦| 久久综合给合久久狠狠狠97色| 久久综合丁香激情久久| 国产精品久久久香蕉| 青青草国产成人久久91网| 人妻无码精品久久亚瑟影视| 久久99精品国产自在现线小黄鸭 | 国内精品久久久久影院网站| 久久久久久综合网天天| 93精91精品国产综合久久香蕉| 丁香色欲久久久久久综合网| 99久久国产热无码精品免费久久久久| 超级碰碰碰碰97久久久久| 国产精品久久久99| 精品国产一区二区三区久久久狼| 久久久久综合中文字幕| 91超碰碰碰碰久久久久久综合| 久久99九九国产免费看小说| 一级做a爰片久久毛片16| 久久青青草原亚洲av无码app| 国产精品一区二区久久精品涩爱 | 久久久综合九色合综国产| 亚洲欧美日韩中文久久| 婷婷久久综合九色综合九七| 久久国产精品国产自线拍免费| 亚洲av伊人久久综合密臀性色 | 天天爽天天狠久久久综合麻豆| 思思久久99热只有频精品66| 亚洲国产精品综合久久网络| 久久久久久无码国产精品中文字幕| 色综合久久综精品| 国产精品女同一区二区久久|