C++設(shè)計(jì)模式之組合模式(Composite)
組合模式為了描述分支包含關(guān)系,也就是我們說的樹形關(guān)系,其對(duì)象分為枝和葉,每一枝可包含枝和葉,直到全部為葉節(jié)點(diǎn)。我們對(duì)枝和葉進(jìn)行行為抽象,可認(rèn)為枝和葉都是Component,而葉是最小的操作單元,其下不存在枝和葉,而枝作為Composite里面存有其下枝和葉的組件列表。
作用
將對(duì)象組合成樹形結(jié)構(gòu)以表示“部分-整體”的層次結(jié)構(gòu),使得用戶對(duì)單個(gè)對(duì)象和組合對(duì)象的使用具有一致性
類視圖
實(shí)現(xiàn)
#include <iostream>
#include <list>
#include <string>
using namespace std;
class menu
{
public:
  menu(string in) : name(in){}
  ~menu(){}
  virtual void Add(menu*) = 0;
  virtual void Remove(menu*) = 0;
  virtual void showname() = 0;
protected:
  string name;
};
class Leafmenu : public menu
{
public:
  Leafmenu(string in) : menu(in){}
  ~Leafmenu(){}
  void showname()
  {
    cout<< "Leaf : " << name << endl;
  }
  virtual void Add(menu*){}
  virtual void Remove(menu*){}
};
class Compositemenu : public menu
{
public:
  Compositemenu(string in) : menu(in){}
  void showname()
  {
    cout<< "Composit : "<< name << endl;
    list<menu*>::iterator iter = m_child.begin();
    while (iter != m_child.end())
    {
      (*iter)->showname();
      iter++;
    }
  }
  virtual void Add(menu*m){ m_child.push_back(m); }
  virtual void Remove(menu*m){ m_child.remove(m); }
private:
  list<menu*> m_child;
};
//調(diào)用實(shí)現(xiàn)
int main
{
  Compositemenu mainmenu("Main");
  /***添加File菜單****/
  Compositemenu *pFile = new Compositemenu("File");
  Leafmenu *pNew = new Leafmenu("New");
  Leafmenu *pOpen = new Leafmenu("Open");
  Leafmenu *pClose = new Leafmenu("Close");
  pFile->Add(pNew);
  pFile->Add(pOpen);
  pFile->Add(pClose);
  mainmenu.Add(pFile);
  /***添加Edit菜單****/
  Compositemenu *pEdit = new Compositemenu("Edit");
  Leafmenu *pCopy = new Leafmenu("Copy");
  Leafmenu *pPaste = new Leafmenu("Paste");
  pEdit->Add(pCopy);
  pEdit->Add(pPaste);
  mainmenu.Add(pFile);
  Leafmenu *pExit = new Leafmenu("Exit");
  Leafmenu *pHelp = new Leafmenu("Help");
  mainmenu.Add(pExit);
  mainmenu.Add(pHelp);
  mainmenu.showname();
  delete pNew;
  delete pOpen;
  delete pClose;
  delete pFile;
  delete pCopy;
  delete pPaste;
  delete pEdit;
  delete pExit;
  delete pHelp;
}
關(guān)于葉對(duì)節(jié)點(diǎn)的操作方法,如上面例子中add、remove、get等,其實(shí)是不需要的,因?yàn)榛惿昝鞯氖羌兲摵瘮?shù),所以必須進(jìn)行實(shí)現(xiàn),但是在調(diào)用時(shí)沒有任何意義,這就帶來了一些使用的風(fēng)險(xiǎn),安全的做法是將這些操作從基類中移除,添加到composite類中,這樣在編譯時(shí)就可以檢查到調(diào)用問題,不過這樣做顯然又阻礙了接口的一致性,權(quán)衡利弊的選擇還需自己根據(jù)需要來。
應(yīng)用場(chǎng)景
常用的樹形結(jié)構(gòu)操作,如文件結(jié)構(gòu)、菜單、組織結(jié)構(gòu)等
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
欄 目:C語言
下一篇:C++設(shè)計(jì)模式之建造者模式(Builder)
本文標(biāo)題:C++設(shè)計(jì)模式之組合模式(Composite)
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/834.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
 - 01-10深入理解C++中常見的關(guān)鍵字含義
 - 01-10使用C++實(shí)現(xiàn)全排列算法的方法詳解
 - 01-10APUE筆記之:進(jìn)程環(huán)境詳解
 - 01-10c++中inline的用法分析
 - 01-10用C++實(shí)現(xiàn)DBSCAN聚類算法
 - 01-10全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法(C++)
 - 01-10C++大數(shù)模板(推薦)
 - 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解
 - 01-10深入C/C++浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式詳解
 


閱讀排行
- 1C語言 while語句的用法詳解
 - 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
 - 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
 - 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
 - 5c語言計(jì)算三角形面積代碼
 - 6什么是 WSH(腳本宿主)的詳細(xì)解釋
 - 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
 - 8正則表達(dá)式匹配各種特殊字符
 - 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
 - 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
 
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
 - 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
 - 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
 - 04-02c語言用函數(shù)寫分段 用c語言表示分段
 - 04-02c語言中對(duì)數(shù)函數(shù)的表達(dá)式 c語言中對(duì)
 - 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
 - 04-02c語言沒有round函數(shù) round c語言
 - 04-02c語言分段函數(shù)怎么求 用c語言求分段
 - 04-02C語言中怎么打出三角函數(shù) c語言中怎
 - 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
 
隨機(jī)閱讀
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
 - 01-11ajax實(shí)現(xiàn)頁面的局部加載
 - 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 - 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
 - 01-10delphi制作wav文件的方法
 - 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
 - 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
 - 01-10C#中split用法實(shí)例總結(jié)
 - 04-02jquery與jsp,用jquery
 - 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
 


