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

C++ Programmer's Cookbook

{C++ 基礎(chǔ)} {C++ 高級} {C#界面,C++核心算法} {設(shè)計模式} {C#基礎(chǔ)}

模式設(shè)計c#--結(jié)構(gòu)型--composite

名稱 Composite
結(jié)構(gòu) o_composite.bmp
意圖 將對象組合成樹形結(jié)構(gòu)以表示“部分-整體”的層次結(jié)構(gòu)。C o m p o s i t e 使得用戶對單個對象和組合對象的使用具有一致性。
適用性
  • 你想表示對象的部分-整體層次結(jié)構(gòu)。
  • 你希望用戶忽略組合對象與單個對象的不同,用戶將統(tǒng)一地使用組合結(jié)構(gòu)中的所有對象。

Code Example
namespace?FactoryMethod_DesignPattern
{
????
using?System;
????
using?System.Collections;

????
abstract?class?Component?
????
{
????????
protected?string?strName;

????????
public?Component(string?name)
????????
{
????????????strName?
=?name;
????????}


????????
abstract?public?void?Add(Component?c);
????
????????
public?abstract?void?DumpContents();
????????
????????
//?other?operations?for?delete,?get,?etc.
????}


????
class?Composite?:?Component
????
{
????????
private?ArrayList?ComponentList?=?new?ArrayList();
????????
????????
public?Composite(string?s)?:?base(s)?{}

????????
override?public?void?Add(Component?c)
????????
{
????????????ComponentList.Add(c);
????????}


????????
public?override?void?DumpContents()
????????
{
????????????
//?First?dump?the?name?of?this?composite?node
????????????Console.WriteLine("Node:?{0}",?strName);

????????????
//?Then?loop?through?children,?and?get?then?to?dump?their?contents
????????????foreach?(Component?c?in?ComponentList)
????????????
{
????????????????c.DumpContents();
????????????}

????????}

????}


????
class?Leaf?:?Component
????
{
????????
public?Leaf(string?s)?:?base(s)?{}

????????
override?public?void?Add(Component?c)
????????
{
????????????Console.WriteLine(
"Cannot?add?to?a?leaf");
????????}


????????
public?override?void?DumpContents()
????????
{
????????????Console.WriteLine(
"Node:?{0}",?strName);
????????}

????}


????
///?<summary>
????
///????Summary?description?for?Client.
????
///?</summary>

????public?class?Client
????
{
????????Component?SetupTree()
????????
{
????????????
//?here?we?have?to?create?a?tree?structure,?
????????????
//?consisting?of?composites?and?leafs.?????
????????????Composite?root?=?new?Composite("root-composite");
????????????Composite?parentcomposite;
????????????Composite?composite;
????????????Leaf?leaf;

????????????parentcomposite?
=?root;
????????????composite?
=?new?Composite("first?level?-?first?sibling?-?composite");
????????????parentcomposite.Add(composite);
????????????leaf?
=?new?Leaf("first?level?-?second?sibling?-?leaf");
????????????parentcomposite.Add(leaf);
????????????parentcomposite?
=?composite;?
????????????composite?
=?new?Composite("second?level?-?first?sibling?-?composite");
????????????parentcomposite.Add(composite);
????????????composite?
=?new?Composite("second?level?-?second?sibling?-?composite");
????????????parentcomposite.Add(composite);

????????????
//?we?will?leaf?the?second?level?-?first?sibling?empty,?and?start?
????????????
//?populating?the?second?level?-?second?sibling?
????????????parentcomposite?=?composite;?
????????????leaf?
=?new?Leaf("third?level?-?first?sibling?-?leaf");
????????????parentcomposite.Add(leaf);
????????????
????????????leaf?
=?new?Leaf("third?level?-?second?sibling?-?leaf");
????????????parentcomposite.Add(leaf);
????????????composite?
=?new?Composite("third?level?-?third?sibling?-?composite");
????????????parentcomposite.Add(composite);

????????????
return?root;
????????}


????????
public?static?int?Main(string[]?args)
????????
{???
???????????????Component?component;
????????????Client?c?
=?new?Client();
????????????component?
=?c.SetupTree();

????????????component.DumpContents();
????????????
return?0;
????????}

????}

}


可以看出,Composite類型的對象可以包含其它Component類型的對象。換而言之,Composite類型對象可以含有其它的樹枝(Composite)類型或樹葉(Leaf)類型的對象。

合成模式的實現(xiàn)根據(jù)所實現(xiàn)接口的區(qū)別分為兩種形式,分別稱為安全模式和透明模式。合成模式可以不提供父對象的管理方法,但合成模式必須在合適的地方提供子對象的管理方法(諸如:add、remove、getChild等)。

透明方式

作為第一種選擇,在Component里面聲明所有的用來管理子類對象的方法,包括add()、remove(),以及getChild()方法。這樣做的好處是所有的構(gòu)件類都有相同的接口。在客戶端看來,樹葉類對象與合成類對象的區(qū)別起碼在接口層次上消失了,客戶端可以同等同的對待所有的對象。這就是透明形式的合成模式。

這個選擇的缺點是不夠安全,因為樹葉類對象和合成類對象在本質(zhì)上是有區(qū)別的。樹葉類對象不可能有下一個層次的對象,因此add()、remove()以及getChild()方法沒有意義,是在編譯時期不會出錯,而只會在運行時期才會出錯。

安全方式

第二種選擇是在Composite類里面聲明所有的用來管理子類對象的方法。這樣的做法是安全的做法,因為樹葉類型的對象根本就沒有管理子類對象的方法,因此,如果客戶端對樹葉類對象使用這些方法時,程序會在編譯時期出錯。

這個選擇的缺點是不夠透明,因為樹葉類和合成類將具有不同的接口。

這兩個形式各有優(yōu)缺點,需要根據(jù)軟件的具體情況做出取舍決定。

安全式的合成模式實現(xiàn): 只有composite有Add ,remove,delete等方法.

以下示例性代碼演示了安全式的合成模式代碼:

//?Composite?pattern?--?Structural?example??
using?System;
using?System.Text;
using?System.Collections;

//?"Component"
abstract?class?Component
{
??
//?Fields
??protected?string?name;

??
//?Constructors
??public?Component(?string?name?)
??
{
????
this.name?=?name;
??}


??
//?Operation
??public?abstract?void?Display(?int?depth?);
}


//?"Composite"
class?Composite?:?Component
{
??
//?Fields
??private?ArrayList?children?=?new?ArrayList();

??
//?Constructors
??public?Composite(?string?name?)?:?base(?name?)?{}

??
//?Methods
??public?void?Add(?Component?component?)
??
{
????children.Add(?component?);
??}

??
public?void?Remove(?Component?component?)
??
{
????children.Remove(?component?);
??}

??
public?override?void?Display(?int?depth?)
??
{
????Console.WriteLine(?
new?String(?'-',?depth?)?+?name?);

????
//?Display?each?of?the?node's?children
????foreach(?Component?component?in?children?)
??????component.Display(?depth?
+?2?);
??}

}


//?"Leaf"
class?Leaf?:?Component
{
??
//?Constructors
??public?Leaf(?string?name?)?:?base(?name?)?{}

??
//?Methods
??public?override?void?Display(?int?depth?)
??
{
????Console.WriteLine(?
new?String(?'-',?depth?)?+?name?);
??}

}


///?<summary>
///?Client?test
///?</summary>

public?class?Client
{
??
public?static?void?Main(?string[]?args?)
??
{
????
//?Create?a?tree?structure
????Composite?root?=?new?Composite(?"root"?);
????root.Add(?
new?Leaf(?"Leaf?A"?));
????root.Add(?
new?Leaf(?"Leaf?B"?));
????Composite?comp?
=?new?Composite(?"Composite?X"?);

????comp.Add(?
new?Leaf(?"Leaf?XA"?)?);
????comp.Add(?
new?Leaf(?"Leaf?XB"?)?);
????root.Add(?comp?);

????root.Add(?
new?Leaf(?"Leaf?C"?));

????
//?Add?and?remove?a?leaf
????Leaf?l?=?new?Leaf(?"Leaf?D"?);
????root.Add(?l?);
????root.Remove(?l?);

????
//?Recursively?display?nodes
????root.Display(?1?);
??}

}

?透明式的合成模式實現(xiàn): 每個里都有add,remove等修改方法.

以下示例性代碼演示了安全式的合成模式代碼:

//?Composite?pattern?--?Structural?example??

using?System;
using?System.Text;
using?System.Collections;

//?"Component"
abstract?class?Component
{
??
//?Fields
??protected?string?name;

??
//?Constructors
??public?Component(?string?name?)
??
{?this.name?=?name;?}

??
//?Methods
??abstract?public?void?Add(Component?c);
??
abstract?public?void?Remove(?Component?c?);
??
abstract?public?void?Display(?int?depth?);
}


//?"Composite"
class?Composite?:?Component
{
??
//?Fields
??private?ArrayList?children?=?new?ArrayList();

??
//?Constructors
??public?Composite(?string?name?)?:?base(?name?)?{}

??
//?Methods
??public?override?void?Add(?Component?component?)
??
{?children.Add(?component?);?}
??
??
public?override?void?Remove(?Component?component?)
??
{?children.Remove(?component?);?}
??
??
public?override?void?Display(?int?depth?)
??
{?
????Console.WriteLine(?
new?String(?'-',?depth?)?+?name?);

????
//?Display?each?of?the?node's?children
????foreach(?Component?component?in?children?)
??????component.Display(?depth?
+?2?);
??}

}


//?"Leaf"
class?Leaf?:?Component
{
??
//?Constructors
??public?Leaf(?string?name?)?:?base(?name?)?{}

??
//?Methods
??public?override?void?Add(?Component?c?)
??
{?Console.WriteLine("Cannot?add?to?a?leaf");?}

??
public?override?void?Remove(?Component?c?)
??
{?Console.WriteLine("Cannot?remove?from?a?leaf");?}

??
public?override?void?Display(?int?depth?)
??
{?Console.WriteLine(?new?String(?'-',?depth?)?+?name?);?}
}


///?<summary>
///?Client?test
///?</summary>

public?class?Client
{
??
public?static?void?Main(?string[]?args?)
??
{
????
//?Create?a?tree?structure
????Composite?root?=?new?Composite(?"root"?);
????root.Add(?
new?Leaf(?"Leaf?A"?));
????root.Add(?
new?Leaf(?"Leaf?B"?));
????Composite?comp?
=?new?Composite(?"Composite?X"?);

????comp.Add(?
new?Leaf(?"Leaf?XA"?)?);
????comp.Add(?
new?Leaf(?"Leaf?XB"?)?);
????root.Add(?comp?);

????root.Add(?
new?Leaf(?"Leaf?C"?));

????
//?Add?and?remove?a?leaf
????Leaf?l?=?new?Leaf(?"Leaf?D"?);
????root.Add(?l?);
????root.Remove(?l?);

????
//?Recursively?display?nodes
????root.Display(?1?);
??}

}

posted on 2006-01-03 15:45 夢在天涯 閱讀(951) 評論(2)  編輯 收藏 引用 所屬分類: Design pattern

評論

# re: 模式設(shè)計c#--結(jié)構(gòu)型--composite 2006-05-18 16:00 夢在天涯

用戶感覺不到他在處理結(jié)合還是一個單體> 這就是此模式的用處所在


  回復(fù)  更多評論   

# re: 模式設(shè)計c#--結(jié)構(gòu)型--composite 2006-05-18 16:09 夢在天涯

用處: 在c++中用基類指針的數(shù)組,在c#中用arraylist都可以 來表示一個帶有分支的樹結(jié)構(gòu)  回復(fù)  更多評論   

公告

EMail:itech001#126.com

導(dǎo)航

統(tǒng)計

  • 隨筆 - 461
  • 文章 - 4
  • 評論 - 746
  • 引用 - 0

常用鏈接

隨筆分類

隨筆檔案

收藏夾

Blogs

c#(csharp)

C++(cpp)

Enlish

Forums(bbs)

My self

Often go

Useful Webs

Xml/Uml/html

搜索

  •  

積分與排名

  • 積分 - 1814985
  • 排名 - 5

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              浪潮色综合久久天堂| 最近中文字幕日韩精品 | 欧美国产精品中文字幕| 免费永久网站黄欧美| 欧美激情1区2区| 欧美揉bbbbb揉bbbbb| 国产精品欧美久久久久无广告| 欧美日韩午夜| 国产欧美日韩激情| 在线观看欧美黄色| 一本色道88久久加勒比精品| 亚洲在线视频免费观看| 久久久99久久精品女同性| 欧美ed2k| 亚洲香蕉成视频在线观看| 久久精品91久久久久久再现| 欧美成人免费视频| 欧美日韩在线一区二区| 国产日韩欧美亚洲一区| 亚洲国产日韩美| 亚洲一区二区少妇| 久久久夜夜夜| 亚洲理论在线观看| 久久国产毛片| 一区二区三区视频在线播放| 亚洲一区二区伦理| 久久精品日韩一区二区三区| 亚洲国产高清在线| 宅男噜噜噜66国产日韩在线观看| 小嫩嫩精品导航| 欧美激情精品| 国内精品模特av私拍在线观看| 亚洲精品视频在线观看网站| 欧美与欧洲交xxxx免费观看 | 国产精品国产三级国产aⅴ入口| 国产日韩综合| 亚洲私拍自拍| 亚洲国产导航| 久久精品国产亚洲5555| 国产精品成人免费| 亚洲久久成人| 毛片av中文字幕一区二区| 亚洲一区二区三区精品在线观看 | 欧美日韩ab片| 亚洲激情在线视频| 久久久久久久波多野高潮日日| 一区二区毛片| 欧美日韩国产美女| 亚洲国产欧美在线| 快射av在线播放一区| 亚洲欧美日韩在线播放| 国产精品久久久久9999| 亚洲综合电影| 99视频在线观看一区三区| 欧美激情女人20p| 亚洲欧洲精品一区二区三区波多野1战4 | 免费h精品视频在线播放| 国产一区二区三区丝袜| 先锋影音久久久| 亚洲尤物视频在线| 国产日产欧产精品推荐色| 欧美夜福利tv在线| 午夜精品福利一区二区蜜股av| 国产精品欧美在线| 欧美在线免费播放| 欧美一区二区三区在线播放| 国产亚洲成av人在线观看导航| 久久九九国产精品| 久久精彩视频| 亚洲国产欧美在线| 亚洲精品久久7777| 麻豆av一区二区三区| 欧美色精品天天在线观看视频| 99热精品在线| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美激情一区二区三区在线| 美女精品网站| 一区二区三区**美女毛片 | 美女网站在线免费欧美精品| 亚洲激情婷婷| 一区二区三区高清视频在线观看| 国产精品高潮在线| 久久精品91| 久色婷婷小香蕉久久| 99re8这里有精品热视频免费 | 日韩视频在线免费| 亚洲一区二区三区四区五区黄 | 国产精品99久久久久久www| 亚洲午夜三级在线| 怡红院精品视频在线观看极品| 亚洲丁香婷深爱综合| 欧美日韩一区二区在线播放| 欧美在线观看视频一区二区三区| 久久综合伊人77777尤物| 亚洲手机成人高清视频| 久久成人这里只有精品| 一区二区三区www| 久久国产精品免费一区| 亚洲一区二区少妇| 久久久天天操| 亚洲一区二区三区涩| 久久午夜激情| 午夜视频久久久| 欧美激情四色| 久久综合一区| 国产精品毛片一区二区三区| 欧美激情精品久久久久久黑人| 国产精品成人一区二区网站软件 | 午夜一区二区三区在线观看| 日韩亚洲国产精品| 久久久久成人精品免费播放动漫| 宅男噜噜噜66一区二区| 免费影视亚洲| 久久综合色综合88| 国产精品入口| 亚洲最快最全在线视频| 亚洲日韩欧美视频一区| 久久久久一区二区| 久久精品久久综合| 国产精品久久久久av| 午夜天堂精品久久久久| 欧美性猛交xxxx乱大交退制版| 久久综合网色—综合色88| 国产精品色婷婷| 99国产成+人+综合+亚洲欧美| 亚洲二区在线观看| 亚洲欧美日韩一区在线观看| 亚洲伊人观看| 欧美日韩一卡二卡| 亚洲愉拍自拍另类高清精品| 久久久久一区二区三区| 欧美在线在线| 国产精品视频成人| 艳女tv在线观看国产一区| 亚洲久久成人| 欧美精品电影| 亚洲日韩欧美视频| 亚洲日韩第九十九页| 你懂的国产精品| 亚洲成在人线av| 在线日韩电影| 欧美不卡一区| 亚洲精品韩国| 亚洲性感激情| 国产精品日韩高清| 午夜日韩在线观看| 六月婷婷一区| 亚洲精品一区二区三区樱花| 欧美黄色免费网站| 这里只有精品视频| 久久高清福利视频| 亚洲第一二三四五区| 欧美不卡在线| 99精品国产在热久久| 欧美一区三区二区在线观看| 国内精品免费午夜毛片| 鲁大师成人一区二区三区| 亚洲三级毛片| 午夜精品久久久久久久白皮肤| 国产日韩视频一区二区三区| 久久九九有精品国产23| 亚洲欧洲一区二区三区在线观看| 亚洲一区二区在线免费观看| 国产一区在线观看视频| 欧美福利视频网站| 亚洲一区尤物| 欧美激情精品久久久久久黑人| 亚洲伊人网站| 亚洲国产视频一区| 国产精品海角社区在线观看| 久久久久欧美精品| 亚洲系列中文字幕| 欧美大片网址| 先锋影院在线亚洲| 亚洲欧洲在线视频| 国产日韩精品一区二区三区在线| 久久噜噜噜精品国产亚洲综合| 日韩午夜三级在线| 久久综合九色综合网站| 一卡二卡3卡四卡高清精品视频| 国产视频久久| 欧美日韩激情小视频| 久久看片网站| 午夜精品久久久久| 亚洲欧洲一区二区三区| 国产精品视频精品视频| 欧美mv日韩mv亚洲| 欧美中文字幕在线观看| 99精品欧美一区二区蜜桃免费| 久久久一区二区| 亚洲自拍偷拍网址| 香蕉久久久久久久av网站| 欧美精品一区二区三区四区| 亚洲综合日韩在线| 亚洲人人精品| 免费一级欧美片在线观看| 午夜在线观看欧美| 国产精品99久久不卡二区 | 亚洲免费一在线| 亚洲激情综合|