青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

那誰的技術博客

感興趣領域:高性能服務器編程,存儲,算法,Linux內核
隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
數據加載中……

常見設計模式的解析和實現(C++)之八-Composite模式

作用:
將對象組合成樹形結構以表示“部分-整體”的層次結構。Composite使得用戶對單個對象和組合對象的使用具有一致性。

UML結構圖:


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

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

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

實現:
1)Composite.h
/********************************************************************
????created:????2006/07/20
????filename:?????Composite.h
????author:????????李創
????????????????
http://m.shnenglu.com/converse/

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


#ifndef?COMPOSITE_H
#define?COMPOSITE_H

#include?
<list>

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

????
//?純虛函數,只提供接口,沒有默認的實現
????virtual?void?Operation()?=?0;

????
//?虛函數,提供接口,有默認的實現就是什么都不做
????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:????????李創
????????????????
http://m.shnenglu.com/converse/

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


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

/*-------------------------------------------------------------------
????Component成員函數的實現

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

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

}


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

}


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


/*-------------------------------------------------------------------
????Leaf成員函數的實現

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

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


/*-------------------------------------------------------------------
????Composite成員函數的實現

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

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:????????李創
????????????????
http://m.shnenglu.com/converse/

????purpose:????Composite模式的測試代碼
********************************************************************
*/


#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 那誰 閱讀(3616) 評論(1)  編輯 收藏 引用 所屬分類: 設計模式

評論

# re: 常見設計模式的解析和實現(C++)之八-Composite模式   回復  更多評論   

這個模式沒啥用:大多數樹狀結構都是不區分葉子節點和父節點的,這個模式中規定了葉子節點和父節點是不一樣的,葉子節點不能提升為父節點,也就不能有自己的葉子節點了~
2012-02-02 10:52 | 學習中
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩一二三区| 亚洲国产欧美不卡在线观看| 久久看片网站| 亚洲精品一区二区在线| 免费日本视频一区| 久久在线免费视频| 女女同性精品视频| 亚洲国产精品成人va在线观看| 亚洲砖区区免费| 亚洲另类黄色| 99精品99| 欧美在线视频免费| 欧美一区二区三区免费大片| 久久九九国产| 亚洲国产精品欧美一二99| 亚洲国产欧美一区二区三区丁香婷| 久久一区亚洲| 欧美成人小视频| 欧美福利在线| 久久久久久久久伊人| 亚洲欧美日韩直播| 亚洲一区二区三区涩| 久久久久久久久蜜桃| 久久亚洲综合色一区二区三区| 欧美日韩精品一区视频| 欧美国产精品人人做人人爱| 亚洲欧美日韩在线一区| 日韩亚洲精品在线| 一本久久a久久免费精品不卡| 欧美国产一区二区| 国产精品激情偷乱一区二区∴| 国产精品免费看片| 国产一区在线看| 亚洲视频一区二区| 欧美14一18处毛片| 亚洲女人天堂成人av在线| 亚洲国产成人久久综合一区| 亚洲欧美日韩爽爽影院| 亚洲茄子视频| 欧美国产国产综合| 欧美与欧洲交xxxx免费观看| 国产精品麻豆欧美日韩ww| 国产精品区一区| 亚洲午夜精品久久久久久浪潮| 欧美成人免费全部| 免费人成精品欧美精品| 亚洲电影一级黄| 91久久国产精品91久久性色| 久久午夜精品| 99精品久久久| av成人国产| 国产欧美日韩三区| 亚洲在线成人| 美女精品视频一区| 99精品国产99久久久久久福利| 亚洲精品视频免费在线观看| 欧美日韩国产精品专区| 欧美一级在线视频| 免播放器亚洲| 亚洲欧美韩国| 久久一区中文字幕| 亚洲一区免费网站| 免费在线播放第一区高清av| 亚洲视频精选| 蜜桃久久精品乱码一区二区| 亚洲免费一在线| 久久免费视频在线| 亚洲综合日本| 免费一区视频| 欧美电影免费观看大全| 国产精品毛片高清在线完整版| 亚洲国产成人精品久久久国产成人一区| 欧美精品成人一区二区在线观看 | 亚洲欧美日韩精品久久亚洲区 | 美女视频黄 久久| 欧美日韩在线一区二区| 欧美成人一区在线| 国产日韩欧美精品| 欧美在线视频免费观看| 欧美在线视频日韩| 国产一区二区三区在线免费观看| 在线综合亚洲| 亚洲一区中文| 国产一区二区在线观看免费| 久久精品国产精品亚洲| 欧美一区二区在线免费观看 | 亚洲一区二区三区免费在线观看 | 国产一区二区三区无遮挡| 亚洲无亚洲人成网站77777| 一区二区欧美在线| 国产精品s色| 久久黄色影院| 亚洲国产日韩欧美| 亚洲免费在线视频| 国产一区二区三区高清| 久久久久久久久久久久久女国产乱 | 午夜亚洲影视| 欧美黄色日本| 午夜免费日韩视频| 亚洲国产专区| 国内精品久久久| 欧美日本亚洲| 国产一区视频网站| 久久精品国产视频| 一区二区三区高清在线观看| 久久综合久久综合久久综合| 99精品欧美一区二区三区| 国产伦精品一区二区三区免费| 亚洲一区激情| 亚洲精选中文字幕| 亚洲精品社区| 亚洲欧洲精品一区二区三区 | 欧美国产日本高清在线| 午夜精品视频网站| 99这里有精品| 亚洲精品乱码久久久久久日本蜜臀| 欧美一级电影久久| 亚洲宅男天堂在线观看无病毒| 亚洲国产成人精品女人久久久 | 中文在线资源观看视频网站免费不卡| 国产精品麻豆成人av电影艾秋 | 一区二区三区四区国产| 亚洲国产精品一区在线观看不卡| 久久久综合视频| 美女精品网站| 欧美sm视频| 亚洲人成网站精品片在线观看| 欧美ed2k| 亚洲一区二区高清视频| 欧美一区二区三区在线看 | 欧美天堂在线观看| 欧美午夜激情小视频| 欧美吻胸吃奶大尺度电影| 久久国产精品久久久久久久久久| 一本色道久久88综合日韩精品| 一本高清dvd不卡在线观看| 亚洲欧美日韩一区在线观看| 久久久久国产精品一区二区| 欧美激情网友自拍| 亚洲毛片视频| 久久蜜臀精品av| 国产精品一卡二卡| 91久久精品国产91性色| 性刺激综合网| 亚洲深夜福利网站| 老司机午夜精品视频在线观看| 欧美亚洲成人免费| 夜久久久久久| 亚洲国产精品久久久久婷婷884| 艳女tv在线观看国产一区| 毛片av中文字幕一区二区| 国产精品久久久久秋霞鲁丝| 99热在这里有精品免费| 免费视频久久| 久久久午夜精品| 曰韩精品一区二区| 久热精品在线视频| 久久成人18免费观看| 国产精品影片在线观看| 午夜天堂精品久久久久| 亚洲一区日韩在线| 国产欧美69| 欧美国产精品久久| 能在线观看的日韩av| 日韩性生活视频| 中文国产一区| 国内精品久久久久伊人av| 久久精品亚洲一区二区三区浴池| 午夜在线视频观看日韩17c| 亚洲国产成人av| 99伊人成综合| 亚洲精美视频| 亚洲天堂视频在线观看| 国产一区91精品张津瑜| 亚洲第一天堂无码专区| 国产精品夜夜嗨| 亚洲国产成人精品视频| 亚洲一区二区精品视频| 亚洲视频1区2区| 影音先锋亚洲电影| 亚洲香蕉网站| 99re在线精品| 久久精品亚洲一区| 亚洲男人的天堂在线| 老鸭窝91久久精品色噜噜导演| 中文在线资源观看网站视频免费不卡| 亚洲在线播放| 新狼窝色av性久久久久久| 猛男gaygay欧美视频| 午夜精品亚洲一区二区三区嫩草| 欧美不卡一卡二卡免费版| 香蕉尹人综合在线观看| 欧美视频不卡中文| 亚洲精品网站在线播放gif| 一区福利视频| 久久国产欧美| 欧美大片网址| 91久久在线视频| 欧美大片免费| 一区二区国产日产|