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

            那誰(shuí)的技術(shù)博客

            感興趣領(lǐng)域:高性能服務(wù)器編程,存儲(chǔ),算法,Linux內(nèi)核
            隨筆 - 210, 文章 - 0, 評(píng)論 - 1183, 引用 - 0
            數(shù)據(jù)加載中……

            常見(jiàn)設(shè)計(jì)模式的解析和實(shí)現(xiàn)(C++)之八-Composite模式

            作用:
            將對(duì)象組合成樹(shù)形結(jié)構(gòu)以表示“部分-整體”的層次結(jié)構(gòu)。Composite使得用戶對(duì)單個(gè)對(duì)象和組合對(duì)象的使用具有一致性。

            UML結(jié)構(gòu)圖:


            抽象基類:
            1)Component:為組合中的對(duì)象聲明接口,聲明了類共有接口的缺省行為(如這里的Add,Remove,GetChild函數(shù)),聲明一個(gè)接口函數(shù)可以訪問(wèn)Component的子組件.

            接口函數(shù):
            1)Component::Operatation:定義了各個(gè)組件共有的行為接口,由各個(gè)組件的具體實(shí)現(xiàn).
            2)Component::Add添加一個(gè)子組件
            3)Component::Remove::刪除一個(gè)子組件.
            4)Component::GetChild:獲得子組件的指針.

            解析:
            Component模式是為解決組件之間的遞歸組合提供了解決的辦法,它主要分為兩個(gè)派生類,其中的Leaf是葉子結(jié)點(diǎn),也就是不含有子組件的結(jié)點(diǎn),而Composite是含有子組件的類.舉一個(gè)例子來(lái)說(shuō)明這個(gè)模式,在UI的設(shè)計(jì)中,最基本的控件是諸如Button,Edit這樣的控件,相當(dāng)于是這里的Leaf組件,而比較復(fù)雜的控件比如List則可也看做是由這些基本的組件組合起來(lái)的控件,相當(dāng)于這里的Composite,它們之間有一些行為含義是相同的,比如在控件上作一個(gè)點(diǎn)擊,移動(dòng)操作等等的,這些都可以定義為抽象基類中的接口虛函數(shù),由各個(gè)派生類去實(shí)現(xiàn)之,這些都會(huì)有的行為就是這里的Operation函數(shù),而添加,刪除等進(jìn)行組件組合的操作只有非葉子結(jié)點(diǎn)才可能有,所以虛擬基類中只是提供接口而且默認(rèn)的實(shí)現(xiàn)是什么都不做.

            實(shí)現(xiàn):
            1)Composite.h
            /********************************************************************
            ????created:????2006/07/20
            ????filename:?????Composite.h
            ????author:????????李創(chuàng)
            ????????????????
            http://m.shnenglu.com/converse/

            ????purpose:????Composite模式的演示代碼
            ********************************************************************
            */


            #ifndef?COMPOSITE_H
            #define?COMPOSITE_H

            #include?
            <list>

            //?組合中的抽象基類
            class?Component
            {
            public:
            ????Component()
            {}
            ????
            virtual?~Component(){}

            ????
            //?純虛函數(shù),只提供接口,沒(méi)有默認(rèn)的實(shí)現(xiàn)
            ????virtual?void?Operation()?=?0;

            ????
            //?虛函數(shù),提供接口,有默認(rèn)的實(shí)現(xiàn)就是什么都不做
            ????virtual?void?Add(Component*?pChild);
            ????
            virtual?void?Remove(Component*?pChild);
            ????
            virtual?Component*?GetChild(int?nIndex);
            }
            ;

            //?派生自Component,是其中的葉子組件的基類
            class?Leaf
            ????:?
            public?Component
            {
            public:
            ????Leaf()
            {}
            ????
            virtual?~Leaf(){}

            ????
            virtual?void?Operation();
            }
            ;

            //?派生自Component,是其中的含有子件的組件的基類
            class?Composite
            ????:?
            public?Component
            {
            public:
            ????Composite()
            {}
            ????
            virtual?~Composite();

            ????
            virtual?void?Operation();

            ????
            virtual?void?Add(Component*?pChild);
            ????
            virtual?void?Remove(Component*?pChild);
            ????
            virtual?Component*?GetChild(int?nIndex);

            private:
            ????
            //?采用list容器去保存子組件
            ????std::list<Component*>????m_ListOfComponent;
            }
            ;

            #endif

            2)Composite.cpp
            /********************************************************************
            ????created:????2006/07/20
            ????filename:?????Composite.cpp
            ????author:????????李創(chuàng)
            ????????????????
            http://m.shnenglu.com/converse/

            ????purpose:????Composite模式的演示代碼
            ********************************************************************
            */


            #include?
            "Composite.h"
            #include?
            <iostream>
            #include?
            <algorithm>

            /*-------------------------------------------------------------------
            ????Component成員函數(shù)的實(shí)現(xiàn)

            ?-------------------------------------------------------------------
            */

            void?Component::Add(Component*?pChild)
            {

            }


            void?Component::Remove(Component*?pChild)
            {

            }


            Component
            *?Component::GetChild(int?nIndex)
            {
            ????
            return?NULL;
            }


            /*-------------------------------------------------------------------
            ????Leaf成員函數(shù)的實(shí)現(xiàn)

            -------------------------------------------------------------------
            */

            void?Leaf::Operation()
            {
            ????std::cout?
            <<?"Operation?by?leaf\n";
            }


            /*-------------------------------------------------------------------
            ????Composite成員函數(shù)的實(shí)現(xiàn)

            -------------------------------------------------------------------
            */

            Composite::
            ~Composite()
            {
            ????std::list
            <Component*>::iterator?iter1,?iter2,?temp;

            ????
            for?(iter1??=?m_ListOfComponent.begin(),?iter2?=?m_ListOfComponent.end();
            ?????????iter1?
            !=?iter2;
            ?????????)
            ????
            {
            ????????temp?
            =?iter1;
            ????????
            ++iter1;
            ????????delete?(
            *temp);
            ????}

            }


            void?Composite::Add(Component*?pChild)
            {
            ????m_ListOfComponent.push_back(pChild);
            }


            void?Composite::Remove(Component*?pChild)
            {
            ????std::list
            <Component*>::iterator?iter;

            ????iter?
            =?find(m_ListOfComponent.begin(),?m_ListOfComponent.end(),?pChild);

            ????
            if?(m_ListOfComponent.end()?!=?iter)
            ????
            {
            ????????m_ListOfComponent.erase(iter);
            ????}

            }


            Component
            *?Composite::GetChild(int?nIndex)
            {
            ????
            if?(nIndex?<=?0?||?nIndex?>?m_ListOfComponent.size())
            ????????
            return?NULL;

            ????std::list
            <Component*>::iterator?iter1,?iter2;
            ????
            int?i;
            ????
            for?(i?=?1,?iter1??=?m_ListOfComponent.begin(),?iter2?=?m_ListOfComponent.end();
            ????????iter1?
            !=?iter2;
            ????????
            ++iter1,?++i)
            ????
            {
            ????????
            if?(i?==?nIndex)
            ????????????
            break;
            ????}


            ????
            return?*iter1;
            }


            void?Composite::Operation()
            {
            ????std::cout?
            <<?"Operation?by?Composite\n";

            ????std::list
            <Component*>::iterator?iter1,?iter2;

            ????
            for?(iter1??=?m_ListOfComponent.begin(),?iter2?=?m_ListOfComponent.end();
            ????????iter1?
            !=?iter2;
            ????????
            ++iter1)
            ????
            {
            ????????(
            *iter1)->Operation();
            ????}

            }

            3)Main.cpp
            /********************************************************************
            ????created:????2006/07/20
            ????filename:?????Main.cpp
            ????author:????????李創(chuàng)
            ????????????????
            http://m.shnenglu.com/converse/

            ????purpose:????Composite模式的測(cè)試代碼
            ********************************************************************
            */


            #include?
            "Composite.h"
            #include?
            <stdlib.h>

            int?main()
            {
            ????Leaf?
            *pLeaf1?=?new?Leaf();
            ????Leaf?
            *pLeaf2?=?new?Leaf();

            ????Composite
            *?pComposite?=?new?Composite;
            ????pComposite
            ->Add(pLeaf1);
            ????pComposite
            ->Add(pLeaf2);
            ????pComposite
            ->Operation();
            ????pComposite
            ->GetChild(2)->Operation();

            ????delete?pComposite;

            ????system(
            "pause");

            ????
            return?0;
            }

            posted on 2006-07-24 01:01 那誰(shuí) 閱讀(3588) 評(píng)論(1)  編輯 收藏 引用 所屬分類: 設(shè)計(jì)模式

            評(píng)論

            # re: 常見(jiàn)設(shè)計(jì)模式的解析和實(shí)現(xiàn)(C++)之八-Composite模式   回復(fù)  更多評(píng)論   

            這個(gè)模式?jīng)]啥用:大多數(shù)樹(shù)狀結(jié)構(gòu)都是不區(qū)分葉子節(jié)點(diǎn)和父節(jié)點(diǎn)的,這個(gè)模式中規(guī)定了葉子節(jié)點(diǎn)和父節(jié)點(diǎn)是不一樣的,葉子節(jié)點(diǎn)不能提升為父節(jié)點(diǎn),也就不能有自己的葉子節(jié)點(diǎn)了~
            2012-02-02 10:52 | 學(xué)習(xí)中
            麻豆亚洲AV永久无码精品久久| 97久久精品人人做人人爽| 久久亚洲国产最新网站| 漂亮人妻被中出中文字幕久久 | 久久久久夜夜夜精品国产| 国产成人精品久久一区二区三区| 久久久久99精品成人片三人毛片 | 精品久久久久久成人AV| 精品综合久久久久久88小说| 国产精品久久新婚兰兰 | 欧美午夜A∨大片久久 | 久久久亚洲裙底偷窥综合 | 精品国产婷婷久久久| 99精品久久精品一区二区| 久久99亚洲综合精品首页| 久久精品天天中文字幕人妻| 日本加勒比久久精品| 韩国无遮挡三级久久| 久久人人爽人人爽人人片AV东京热| 久久久久综合网久久| 久久综合给合久久狠狠狠97色| 久久99精品免费一区二区| 久久99精品国产99久久6男男| 久久久亚洲AV波多野结衣| 久久伊人色| 久久福利片| 国产精品激情综合久久| 国产精品一久久香蕉产线看| 亚洲精品无码成人片久久| 久久国产亚洲精品| 亚洲国产成人久久综合碰| 久久青青草原精品影院| 97久久久精品综合88久久| 97久久精品人妻人人搡人人玩| 久久久久久夜精品精品免费啦| 色综合久久中文字幕无码| 亚洲午夜久久久影院| 久久午夜羞羞影院免费观看| 久久精品亚洲精品国产色婷| 久久国产色AV免费看| 嫩草影院久久99|