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

            積木

            No sub title

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

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

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            轉(zhuǎn)載自:http://patmusing.blog.163.com/blog/static/135834960201002321018760/


            在面向?qū)ο蟮南到y(tǒng)中,我們經(jīng)常會(huì)遇到一類具有
            容器特征的對(duì)象,即它們?cè)诔洚?dāng)對(duì)象的同時(shí),又是其他對(duì)象的容器。

            舉例:

            在操作系統(tǒng)中,文件的概念很廣泛,其中文件可以是普通文件,也可以是目錄(Unix中,設(shè)備也是文件),目錄中可以存放文件。Composite設(shè)計(jì)模式就是將客戶代碼與復(fù)雜的對(duì)象容器結(jié)構(gòu)解耦,讓對(duì)象容器自己來實(shí)現(xiàn)自身的復(fù)雜結(jié)構(gòu),從而使得客戶代碼就像處理簡單對(duì)象(文件)一樣來處理復(fù)雜的對(duì)象容器(目錄)

            “Compose objects into tree structures to represent part-whole hierarchies. Composite lets clients treat individual objects and compositions of objects uniformly.” – GoF

            10. C++實(shí)現(xiàn)Structural - Composite模式 - 玄機(jī)逸士 - 玄機(jī)逸士博客

            調(diào)用Directory類對(duì)象的process函數(shù),和調(diào)用PhysicalFile類對(duì)象的process一樣簡單。

            從上面的UML類圖中,可以看出DirectoryFile這兩個(gè)類之間的關(guān)系:

            1. Directory “is a”File

            2. Directory “has a(more)” File

            這是典型的遞歸結(jié)構(gòu)。因此在處理遞歸問題時(shí),如果必要,可以考慮采用Composite模式。后面要講到的Decorator模式也是如此。

            // Composite.h

            #include <iostream>

            #include <list>

            using namespace std;

            class File

            {

            public:

            virtual void process() = 0;

            // 虛函數(shù):增加一個(gè)文件

            virtual void add(File* file)

            {

            }

            // 虛函數(shù):刪除一個(gè)文件

            virtual void remove(File* file)

            {

            }

            public:

            virtual ~File()

            {

            cout << "in the destructor of File..." << endl;

            }

            };

            // 葉子節(jié)點(diǎn)

            class PhysicalFile : public File

            {

            public:

            void process()

            {

            cout << "process() in PhysicalFile..." << endl;

            }

            public:

            ~PhysicalFile()

            {

            cout << "in the destructor of PhysicalFile..." << endl;

            }

            };

            // 容器節(jié)點(diǎn):Composite節(jié)點(diǎn)

            class Directory : public File

            {

            private:

            list<File*> file_list;

            public:

            Directory()

            {

            }

            void process()

            {

            cout << "process() in Directory..." << endl;

            if(!file_list.empty())

            {

            for(list<File*>::iterator it = file_list.begin(); it != file_list.end(); it++)

            {

            File* f = *it;

            f->process();

            }

            }

            }

            void add(File* file)

            {

            file_list.push_back(file);

            }

            void remove(File* file)

            {

            file_list.remove(file);

            }

            public:

            ~Directory()

            {

            cout << "in the destructor of Directory..." << endl;

            }

            };

            // Composite.cpp

            #include "Composite.h"

            int main(int argc, char **argv)

            {

            File *f1 = new Directory;

            File *f2 = new Directory;

            File *f3 = new PhysicalFile;

            f2->add(f3);

            f1->add(f2);

            File *f4 = new Directory;

            File *f5 = new Directory;

            File *f6 = new Directory;

            File *f7 = new PhysicalFile;

            f6->add(f7);

            f5->add(f6);

            f4->add(f5);

            f1->add(f4);

            f1->process();

            f1->remove(f4);

            cout << "+++++++++++++++++++++++" << endl;

            f1->process();

            // STL container中的元素是指針對(duì)象,那么必須手動(dòng)刪除。

            delete f1;

            delete f2;

            delete f3;

            delete f4;

            delete f5;

            delete f6;

            delete f7;

            return 0;

            }

            上述程序中,各對(duì)象之間的關(guān)系如下圖:

            10. C++實(shí)現(xiàn)Structural - Composite模式 - 玄機(jī)逸士 - 玄機(jī)逸士博客

            其中f3f7PhysicalFile對(duì)象。f1包含了f2f4f2包含了f3f4包含了f5f5包含了f6f6包含了f7

            運(yùn)行結(jié)果如下:

            process() in Directory... // f1

            process() in Directory... // f2

            process() in PhysicalFile... // f3

            process() in Directory... // f4

            process() in Directory... // f5

            process() in Directory... // f6

            process() in PhysicalFile... // f7

            +++++++++++++++++++++++ // 刪除f4后的輸出(可以看到f4及其包含的對(duì)象全部被刪除了)

            process() in Directory... // f1

            process() in Directory... // f2

            process() in PhysicalFile... // f3

            in the destructor of Directory...

            in the destructor of File...

            in the destructor of Directory...

            in the destructor of File...

            in the destructor of PhysicalFile...

            in the destructor of File...

            in the destructor of Directory...

            in the destructor of File...

            in the destructor of Directory...

            in the destructor of File...

            in the destructor of Directory...

            in the destructor of File...

            in the destructor of PhysicalFile...

            in the destructor of File...



            posted on 2013-03-07 22:33 Jacc.Kim 閱讀(227) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 設(shè)計(jì)模式
            久久久久国产| 伊人久久大香线蕉影院95| 亚洲国产一成人久久精品| 韩国无遮挡三级久久| 亚洲AⅤ优女AV综合久久久| 亚洲AV无码久久| 国内精品久久久久久久影视麻豆| 久久青青草视频| 91性高湖久久久久| 伊人久久大香线焦AV综合影院| 国产精品美女久久久久av爽| 国内精品久久久久影院薰衣草| 精品久久久久久无码免费| 国产精品久久永久免费| 色综合久久中文字幕无码| 午夜精品久久久久久| 热99re久久国超精品首页| 99久久免费国产精精品| 色婷婷久久综合中文久久蜜桃av| 伊人久久精品影院| 久久99亚洲综合精品首页| 99久久精品免费看国产| 精品久久777| 久久精品国产亚洲AV麻豆网站| 精品久久久久久国产| 青青热久久国产久精品| 色综合久久88色综合天天 | 国产精品欧美久久久久无广告| 久久久青草青青亚洲国产免观| 国产精品美女久久久久久2018| 久久久久亚洲AV无码麻豆| AV无码久久久久不卡蜜桃| 无码人妻少妇久久中文字幕蜜桃| 97精品国产97久久久久久免费| 久久成人国产精品免费软件| 久久久久免费精品国产| 亚洲精品国精品久久99热一| 亚洲中文字幕久久精品无码喷水 | 久久久亚洲欧洲日产国码二区| 久久久久亚洲av综合波多野结衣| 波多野结衣久久|