• <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>

            emptysoul

              C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
              25 Posts :: 0 Stories :: 23 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(18)

            我參與的團(tuán)隊(duì)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            組合模式(Composite)的定義為:組合多個(gè)對(duì)象形成樹(shù)形結(jié)構(gòu),以表示整體-部分的結(jié)構(gòu)層次。組合模式對(duì)單個(gè)對(duì)象和組合對(duì)象的使用具有一致性。其結(jié)構(gòu)圖如下:
             

            例如一個(gè)新聞的樹(shù)形菜單,它包含很多原始菜單(如國(guó)內(nèi)、國(guó)際),以及由其子菜單組成的組合節(jié)點(diǎn)(如國(guó)內(nèi)新聞下的時(shí)事、社會(huì)等),結(jié)構(gòu)圖如下:


            實(shí)現(xiàn)代碼:
            //Menu.h
            #include <string>

            class Menu  
            {
            public:
                
            virtual ~Menu();

                
            virtual void Add(Menu*);
                
            virtual void Remove(Menu*);
                
            virtual Menu* GetChild(int);
                
            virtual void Display() = 0;
            protected:
                Menu();
                Menu(std::
            string);
                std::
            string m_strName;
            };

            //Menu.cpp
            #include "stdafx.h"
            #include 
            "Menu.h"

            Menu::Menu()
            {

            }

            Menu::Menu(std::
            string strName) : m_strName(strName)
            {

            }

            Menu::
            ~Menu()
            {

            }

            void Menu::Add(Menu* pMenu)
            {}

            void Menu::Remove(Menu* pMenu)
            {}

            Menu
            * Menu::GetChild(int index)
            {
                
            return NULL;
            }

            //SubMenu.h
            #include "Menu.h"

            class SubMenu : public Menu  
            {
            public:
                SubMenu();
                SubMenu(std::
            string);
                
            virtual ~SubMenu();

                
            void Display();
            };

            //SubMenu.cpp
            #include "stdafx.h"
            #include 
            "SubMenu.h"
            #include 
            <iostream>

            using namespace std;

            SubMenu::SubMenu()
            {

            }

            SubMenu::SubMenu(
            string strName) : Menu(strName)
            {

            }

            SubMenu::
            ~SubMenu()
            {

            }

            void SubMenu::Display()
            {
                cout 
            << m_strName << endl;
            }

            //CompositMenu.h
            #include "Menu.h"
            #include 
            <vector>

            class CompositMenu : public Menu
            {
            public:
                CompositMenu();
                CompositMenu(std::
            string);
                
            virtual ~CompositMenu();

                
            void Add(Menu*);
                
            void Remove(Menu*);
                Menu
            * GetChild(int);
                
            void Display();
            private:
                std::vector
            <Menu*> m_vMenu;
            };

            //CompositMenu.cpp
            #include "stdafx.h"
            #include 
            "CompositMenu.h"
            #include 
            <iostream>

            using namespace std;

            CompositMenu::CompositMenu()
            {
                
            }

            CompositMenu::CompositMenu(
            string strName) : Menu(strName)
            {

            }

            CompositMenu::
            ~CompositMenu()
            {

            }

            void CompositMenu::Add(Menu* pMenu)
            {
                m_vMenu.push_back(pMenu);
            }

            void CompositMenu::Remove(Menu* pMenu)
            {
                m_vMenu.erase(
            &pMenu);
            }

            Menu
            * CompositMenu::GetChild(int index)
            {
                
            return m_vMenu[index];
            }

            void CompositMenu::Display()
            {
                cout 
            << "+" << m_strName << endl;
                vector
            <Menu*>::iterator it = m_vMenu.begin();
                
            for (; it != m_vMenu.end(); ++it)
                {
                    cout 
            << "|-";
                    (
            *it)->Display();
                }
            }

            #include 
            "stdafx.h"
            #include 
            "Menu.h"
            #include 
            "SubMenu.h"
            #include 
            "CompositMenu.h"

            int main(int argc, char* argv[])
            {
                Menu
            * pMenu = new CompositMenu("國(guó)內(nèi)新聞");
                pMenu
            ->Add(new SubMenu("時(shí)事新聞"));
                pMenu
            ->Add(new SubMenu("社會(huì)新聞"));
                pMenu
            ->Display();
                pMenu 
            = new CompositMenu("國(guó)際新聞");
                pMenu
            ->Add(new SubMenu("國(guó)際要聞"));
                pMenu
            ->Add(new SubMenu("環(huán)球視野"));
                pMenu
            ->Display();

                
            return 0;
            }

            最后輸出為:
            +國(guó)內(nèi)新聞
            |-時(shí)事新聞
            |-社會(huì)新聞
            +國(guó)際新聞
            |-國(guó)際要聞
            |-環(huán)球視野
            posted on 2009-02-11 19:51 emptysoul 閱讀(2056) 評(píng)論(3)  編輯 收藏 引用

            Feedback

            # re: 設(shè)計(jì)模式-組合模式 2009-07-09 13:58 lu-bei
            嘿,例子很棒,只是存在內(nèi)存泄露^.^

            Thanks for your sample!  回復(fù)  更多評(píng)論
              

            # re: 設(shè)計(jì)模式-組合模式[未登錄](méi) 2011-11-29 22:49 jemmyLiu
            你的其他的設(shè)計(jì)模式我都看過(guò)了 實(shí)現(xiàn)的挺簡(jiǎn)單明了的 就是沒(méi)有釋放內(nèi)存的習(xí)慣 像java轉(zhuǎn)過(guò)來(lái)的 呵呵  回復(fù)  更多評(píng)論
              

            # re: 設(shè)計(jì)模式-組合模式 2012-08-27 20:12 江南煙雨
            @lu-bei
            只需要在CompositeMenu的析構(gòu)函數(shù)中delete vector中的各個(gè)指針就可以了~  回復(fù)  更多評(píng)論
              


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


            久久福利片| av无码久久久久不卡免费网站 | 久久无码一区二区三区少妇| 日本精品一区二区久久久| 亚洲精品乱码久久久久66| 18岁日韩内射颜射午夜久久成人| 伊人久久五月天| 国产精品99久久久久久董美香| 亚洲精品美女久久久久99| 成人a毛片久久免费播放| 亚洲AV无码久久精品成人| 久久久久久国产精品免费免费| 久久久久高潮毛片免费全部播放 | 狠狠综合久久综合88亚洲| 97超级碰碰碰碰久久久久| 午夜久久久久久禁播电影| 久久性生大片免费观看性| 国产精品久久久久AV福利动漫 | 久久精品国产99国产精品导航 | 久久伊人色| 精品综合久久久久久88小说 | 狠狠色综合网站久久久久久久高清| 国产福利电影一区二区三区久久老子无码午夜伦不 | 国产精品久久久久久久久软件| 91麻精品国产91久久久久| 久久综合九色综合精品| 久久夜色精品国产噜噜亚洲AV| 久久久久av无码免费网| 久久天天躁狠狠躁夜夜2020一| 国产精品午夜久久| 国产999精品久久久久久| 久久久女人与动物群交毛片| 狠狠色狠狠色综合久久| 久久综合精品国产二区无码| 99精品久久精品一区二区| 色婷婷久久综合中文久久蜜桃av | 久久99精品久久久久久动态图| 亚洲人成网亚洲欧洲无码久久| 午夜精品久久久久| 无码久久精品国产亚洲Av影片 | 伊人久久五月天|