婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解組合模式的結(jié)構(gòu)及其在Ruby設(shè)計(jì)模式編程中的運(yùn)用

詳解組合模式的結(jié)構(gòu)及其在Ruby設(shè)計(jì)模式編程中的運(yùn)用

熱門標(biāo)簽:白銀外呼paas系統(tǒng) 滴滴外呼系統(tǒng) 高德地圖標(biāo)注客服 常德電銷平臺外呼系統(tǒng)軟件價(jià)格 電銷機(jī)器人廠商代理 百度地圖標(biāo)注自定義圖片 湖州u友防封電銷卡 地圖標(biāo)注賺錢項(xiàng)目注冊 徐州網(wǎng)絡(luò)外呼系統(tǒng)哪個好

定義:也叫合成模式,或者部分-整體模式,主要是用來描述部分與整體的關(guān)系,定義,將對象組合成樹形結(jié)構(gòu)以表示“部分-整體”的層次結(jié)構(gòu),使得用戶對單個對象和組合對象的使用具有一致性。

類圖:

角色說明:

Componnent抽象構(gòu)件角色:定義參加組合對象的共有方法和屬性,可以定義一些默認(rèn)的行為或?qū)傩浴?br /> Leaf葉子構(gòu)件:葉子對象,其下再也沒有其他的分支,也就是遍歷的最小單位。
Composite樹枝構(gòu)件:樹枝對象,它的作用是組合樹枝節(jié)點(diǎn)和葉子節(jié)點(diǎn)形成一個樹形結(jié)構(gòu)。

實(shí)例:
聽說你們公司最近新推出了一款電子書閱讀應(yīng)用,市場反應(yīng)很不錯,應(yīng)用里還有圖書商城,用戶可以在其中隨意選購自己喜歡的書籍。你們公司也是對此項(xiàng)目高度重視,加大了投入力度,決定給此應(yīng)用再增加點(diǎn)功能。
好吧,你也知道你是逃不過此劫了,沒過多久你的leader就找到了你。他告訴你目前的應(yīng)用對每本書的瀏覽量和銷售量做了統(tǒng)計(jì),但現(xiàn)在想增加對每個書籍分類的瀏覽量和銷售量以及所有書籍總的瀏覽量和銷售量做統(tǒng)計(jì)的功能,希望你可以來完成這項(xiàng)功能。
領(lǐng)導(dǎo)安排的工作當(dāng)然是推脫不掉的,你只能硬著頭皮上了,不過好在這個功能看起來也不怎么復(fù)雜。
你比較喜歡看小說,那么就從小說類的統(tǒng)計(jì)功能開始做起吧。首先通過get_all_novels方法可以獲取到所有的小說名,然后將小說名傳入get_browse_count方法可以得到該書的瀏覽量,將小說名傳入get_sale_count方法可以得到該書的銷售量。你目前只有這幾個已知的API可以使用,那么開始動手吧!

def get_novels_browse_count 
  browse_count = 0 
  all_novels = get_all_novels() 
  all_novels.each do |novel| 
    browse_count += get_browse_count(novel) 
  end 
  browse_count 
end 
 
def get_novels_sale_count 
  sale_count = 0 
  all_novels = get_all_novels() 
  all_novels.each do |novel| 
    sale_count += get_browse_count(novel) 
  end 
  sale_count 
end 

很快你就寫下了以上兩個方法,這兩個方法都是通過獲取到所有的小說名,然后一一計(jì)算每本小說的瀏覽量和銷售量,最后將結(jié)果相加得到總量。
小說類的統(tǒng)計(jì)就完成了,然后你開始做計(jì)算機(jī)類書籍的統(tǒng)計(jì)功能,代碼如下所示:

def get_computer_books_browse_count 
  browse_count = 0 
  all_computer_books = get_all_computer_books() 
  all_computer_books.each do |computer_book| 
    browse_count += get_browse_count(computer_book) 
  end 
  browse_count 
end 
 
def get_computer_books_sale_count 
  sale_count = 0 
  all_computer_books = get_all_computer_books() 
  all_computer_books.each do |computer_book| 
    sale_count += get_browse_count(computer_book) 
  end 
  sale_count 
end 

除了使用了get_all_computer_books方法獲取到所有的計(jì)算機(jī)類書名,其它的代碼基本和小說統(tǒng)計(jì)中的是一樣的。
現(xiàn)在你才完成了兩類書籍的統(tǒng)計(jì)功能,后面還有醫(yī)學(xué)類、自然類、歷史類、法律類、政治類、哲學(xué)類、旅游類、美食類等等等等書籍。你突然意識到了一些問題的嚴(yán)重性,工作量大倒還不算什么,但再這么寫下去,你的方法就要爆炸了,這么多的方法讓人看都看不過來,別提怎么使用了。
這個時(shí)候你只好向你的leader求助了,跟他說明了你的困惑。只見你的leader思考了片刻,然后自信地告訴你,使用組合模式不僅可以輕松消除你的困惑,還能出色地完成功能。
他立刻向你秀起了編碼操作,首先定義一個Statistics類,里面有兩個方法:

class Statistics 
   
  def get_browse_count 
    raise "You should override this method in subclass." 
  end 
   
  def get_sale_count 
    raise "You should override this method in subclass." 
  end 
   
end 

這兩個方法都是簡單地拋出一個異常,因?yàn)樾枰谧宇愔兄貙戇@兩個方法。
然后定義一個用于統(tǒng)計(jì)小說類書籍的NovelStatistics類,繼承剛剛定義的Statistics類,并重寫Statistics中的兩個方法:

class NovelStatistics  Statistics 
 
  def get_browse_count 
    browse_count = 0 
    all_novels = get_all_novels() 
    all_novels.each do |novel| 
      browse_count += get_browse_count(novel) 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    all_novels = get_all_novels() 
    all_novels.each do |novel| 
      sale_count += get_browse_count(novel) 
    end 
    sale_count 
  end 
 
end 

在這兩個方法中分別統(tǒng)計(jì)了小說類書籍的瀏覽量和銷售量。那么同樣的方法,你的leader又定義了一個ComputerBookStatistics類用于統(tǒng)計(jì)計(jì)算機(jī)類書籍的瀏覽量和銷售量:

class ComputerBookStatistics  Statistics 
 
  def get_browse_count 
    browse_count = 0 
    all_computer_books = get_all_computer_books() 
    all_computer_books.each do |computer_book| 
      browse_count += get_browse_count(computer_book) 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    all_computer_books = get_all_computer_books() 
    all_computer_books.each do |computer_book| 
      sale_count += get_browse_count(computer_book) 
    end 
    sale_count 
  end 
 
end 

這樣將具體的統(tǒng)計(jì)實(shí)現(xiàn)分散在各個類中,就不會再出現(xiàn)你剛剛那種方法爆炸的情況了。不過這還沒開始真正使用組合模式呢,好戲還在后頭,你的leader吹噓道。

再定義一個MedicalBookStatistics類繼承Statistics,用于統(tǒng)計(jì)醫(yī)學(xué)類書籍的瀏覽量和銷售量,代碼如下如示:

class MedicalBookStatistics  Statistics 
 
  def get_browse_count 
    browse_count = 0 
    all_medical_books = get_all_medical_books() 
    all_medical_books.each do |medical_book| 
      browse_count += get_browse_count(medical_book) 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    all_medical_books = get_all_medical_books() 
    all_medical_books.each do |medical_book| 
      sale_count += get_browse_count(medical_book) 
    end 
    sale_count 
  end 
 
end 

不知道你發(fā)現(xiàn)了沒有,計(jì)算機(jī)類書籍和醫(yī)學(xué)類書籍其實(shí)都算是科技類書籍,它們是可以組合在一起的。這個時(shí)候你的leader定義了一個TechnicalStatistics類用于對科技這一組合類書籍進(jìn)行統(tǒng)計(jì):

class TechnicalStatistics  Statistics 
 
  def initialize 
    @statistics = [] 
    @statistics  ComputerBookStatistics.new 
    @statistics  MedicalBookStatistics.new 
  end 
 
  def get_browse_count 
    browse_count = 0 
    @statistics.each do |s| 
      browse_count += s.get_browse_count 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    @statistics.each do |s| 
      sale_count += s.get_sale_count 
    end 
    sale_count 
  end 
 
end 

可以看到,由于這個類是組合類,和前面幾個類還是有不少區(qū)別的。首先TechnicalStatistics中有一個構(gòu)造函數(shù),在構(gòu)造函數(shù)中將計(jì)算機(jī)類書籍和醫(yī)學(xué)類書籍作為子分類添加到statistics數(shù)組當(dāng)中,然后分別在get_browse_count和get_sale_count方法中遍歷所有的子分類,計(jì)算出它們各自的瀏覽量和銷售量,然后相加得到總額返回。
組合模式的擴(kuò)展性非常好,沒有各種條條框框,想怎么組合就怎么組合,比如所有書籍就是由各個分類組合而來的,你的leader馬上又向你炫耀了統(tǒng)計(jì)所有書籍的瀏覽量和銷售量的辦法。
定義一個AllStatistics類繼承Statistics,具體代碼如下所示:

class AllStatistics  Statistics 
 
  def initialize 
    @statistics = [] 
    @statistics  NovelStatistics.new 
    @statistics  TechnicalStatistics.new 
  end 
 
  def get_browse_count 
    browse_count = 0 
    @statistics.each do |s| 
      browse_count += s.get_browse_count 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    @statistics.each do |s| 
      sale_count += s.get_sale_count 
    end 
    sale_count 
  end 
 
end 

在AllStatistics的構(gòu)造函數(shù)中將小說類書籍和科技類書籍作為子分類添加到了statistics數(shù)組當(dāng)中,目前你也就只寫好了這幾個分類。然后使用同樣的方法在get_browse_count和get_sale_count方法中統(tǒng)計(jì)出所有書籍的瀏覽量和銷售量。
當(dāng)前組合結(jié)構(gòu)的示意圖如下:

現(xiàn)在你就可以非常方便的得到任何分類書籍的瀏覽量和銷售量了,比如說獲取科技類書籍的瀏覽量,你只需要調(diào)用:

TechnicalStatistics.new.get_browse_count 

而獲取所有書籍的總銷量,你只需要調(diào)用:

AllStatistics.new.get_sale_count 

當(dāng)然你后面還可以對這個組合結(jié)構(gòu)隨意地改變,添加各種子分類書籍,而且子分類的層次結(jié)構(gòu)可以任意深,正如前面所說,組合模式的擴(kuò)展性非常好。
你的leader告訴你,目前他寫的這份代碼重復(fù)度比較高,其實(shí)還可以好好優(yōu)化一下的,把冗余代碼都去除掉。當(dāng)然這個任務(wù)就交給你來做了,你的leader可是大忙人,早就一溜煙跑開了。

總結(jié)

組合模式的優(yōu)點(diǎn):
能夠靈活的組合局部對象和整體對象之間的關(guān)心,對客戶端來說,局部對象和整體對象的調(diào)用沒有差別,使調(diào)用簡單。

組合模式的缺點(diǎn):
1.組合操作的成本很高,如果一個對象樹中有很多子對象,可能一個簡單的調(diào)用就可能使系統(tǒng)崩潰;
2.對象持久化的問題,組合模式是樹形結(jié)構(gòu),不能很好地在關(guān)系數(shù)據(jù)庫中保存數(shù)據(jù),但是卻非常適合用于xml持久化。

組合模式的適用場景:
1.維護(hù)和展示部分—整體關(guān)系得場景,如樹形菜單、文件和文件夾管理。
2.從一個整體中能夠獨(dú)立出部分模塊或功能的場景。

您可能感興趣的文章:
  • 設(shè)計(jì)模式中的觀察者模式在Ruby編程中的運(yùn)用實(shí)例解析
  • 實(shí)例解析Ruby設(shè)計(jì)模式開發(fā)中對觀察者模式的實(shí)現(xiàn)
  • 深入剖析Ruby設(shè)計(jì)模式編程中對命令模式的相關(guān)使用
  • Ruby設(shè)計(jì)模式編程中對外觀模式的應(yīng)用實(shí)例分析
  • 設(shè)計(jì)模式中的模板方法模式在Ruby中的應(yīng)用實(shí)例兩則
  • 實(shí)例解析Ruby設(shè)計(jì)模式編程中Strategy策略模式的使用
  • 實(shí)例講解Ruby使用設(shè)計(jì)模式中的裝飾器模式的方法
  • Ruby設(shè)計(jì)模式編程中使用Builder建造者模式的實(shí)例
  • 詳解Ruby設(shè)計(jì)模式編程中對單例模式的運(yùn)用
  • Ruby設(shè)計(jì)模式編程之適配器模式實(shí)戰(zhàn)攻略
  • Ruby使用設(shè)計(jì)模式中的代理模式與裝飾模式的代碼實(shí)例
  • Ruby中使用設(shè)計(jì)模式中的簡單工廠模式和工廠方法模式
  • 解析proxy代理模式在Ruby設(shè)計(jì)模式開發(fā)中的運(yùn)用

標(biāo)簽:梧州 張家界 荊門 公主嶺 永州 三沙 遼寧 普洱

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解組合模式的結(jié)構(gòu)及其在Ruby設(shè)計(jì)模式編程中的運(yùn)用》,本文關(guān)鍵詞  詳解,組合,模式,的,結(jié)構(gòu),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解組合模式的結(jié)構(gòu)及其在Ruby設(shè)計(jì)模式編程中的運(yùn)用》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解組合模式的結(jié)構(gòu)及其在Ruby設(shè)計(jì)模式編程中的運(yùn)用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲图片欧美视频| 亚洲欧洲精品天堂一级| 国产精品理伦片| 欧洲视频一区二区| 日本午夜精品一区二区三区电影| 国产日韩v精品一区二区| 欧美日韩卡一卡二| 国产一区二区三区四| 国产精品传媒入口麻豆| 欧美中文字幕不卡| www.亚洲在线| 视频一区视频二区中文字幕| 中文字幕第一区第二区| 一本大道综合伊人精品热热| 国产在线麻豆精品观看| 亚洲综合无码一区二区| 欧美日韩亚洲不卡| 国产mv日韩mv欧美| 亚洲精品乱码久久久久久黑人| 在线观看视频91| 韩国v欧美v亚洲v日本v| 亚洲一区在线观看免费观看电影高清| 欧美一区二区三区男人的天堂| 日本精品一区二区三区四区的功能| 国产精品1024| 国产成人日日夜夜| 国产麻豆9l精品三级站| 久久精工是国产品牌吗| 久久99国产精品免费网站| 国产综合久久久久久鬼色 | 日韩成人免费看| 日韩成人午夜精品| 精品一区二区久久久| 国产精品亚洲午夜一区二区三区| 国产成人精品免费视频网站| 99久久婷婷国产| 欧美图区在线视频| 欧美三级视频在线观看 | 久久综合久久99| 久久新电视剧免费观看| 日本一区二区电影| 一区二区三区久久久| 亚洲图片自拍偷拍| 九九**精品视频免费播放| 国产精品一区久久久久| 国产99久久久国产精品| 91免费观看在线| 欧美丰满嫩嫩电影| 欧美日韩一区二区三区在线| 5月丁香婷婷综合| 538prom精品视频线放| 一本色道综合亚洲| av中文字幕一区| 国产乱码精品一区二区三 | 亚洲欧洲av一区二区三区久久| 国产精品亚洲人在线观看| 亚洲同性同志一二三专区| 日韩一区二区免费在线观看| 不卡高清视频专区| 国产精品污www在线观看| 国产精品高潮呻吟久久| 色美美综合视频| 一色屋精品亚洲香蕉网站| 久久久蜜桃精品| 久久老女人爱爱| 日韩欧美资源站| 亚洲午夜国产一区99re久久| 亚欧色一区w666天堂| 欧美精品一二三| 国产成人亚洲综合a∨猫咪| 中文字幕在线播放不卡一区| 国产亚洲精品精华液| 亚洲男人天堂av网| 久久久综合网站| 欧美精品免费视频| 精品久久五月天| 久久久亚洲欧洲日产国码αv| 成人白浆超碰人人人人| 国产精品久久午夜夜伦鲁鲁| 7777精品伊人久久久大香线蕉完整版 | 国产精品自在在线| 亚洲视频一区二区在线观看| 欧日韩精品视频| 久久成人麻豆午夜电影| 日韩成人av影视| 青青青爽久久午夜综合久久午夜| 欧美午夜理伦三级在线观看| 成人免费三级在线| 欧美人妖巨大在线| 成熟亚洲日本毛茸茸凸凹| 这里是久久伊人| 欧美一级一区二区| 色综合天天综合网天天狠天天| k8久久久一区二区三区| 亚洲欧美激情一区二区| 欧美日韩视频在线一区二区 | 欧美怡红院视频| 欧美精品一级二级三级| 国产成人激情av| 欧美丰满一区二区免费视频| 中文字幕一区二区三区四区| 一区二区三区日韩欧美精品| 91蜜桃免费观看视频| 91成人免费网站| 538prom精品视频线放| 不卡的电视剧免费网站有什么| 国产原创一区二区| 国产精品1区2区| 日韩精品福利网| av不卡一区二区三区| 国产精品久久久久久户外露出| 日韩国产精品久久| 久久只精品国产| 亚洲在线成人精品| 91蜜桃视频在线| 日韩成人一区二区| 亚洲午夜精品在线| 欧美色偷偷大香| 亚洲妇女屁股眼交7| 国产成人无遮挡在线视频| 成人国产亚洲欧美成人综合网| 亚洲在线观看免费视频| 午夜精品成人在线视频| 成人精品gif动图一区| 亚洲黄色尤物视频| 亚洲天堂2014| 亚洲最新视频在线观看| 欧美午夜在线一二页| 欧美卡1卡2卡| 91精品免费在线观看| 精品美女一区二区三区| 亚洲情趣在线观看| 色婷婷精品大在线视频| 国产精品一线二线三线| 国产精品乱人伦一区二区| 丝袜国产日韩另类美女| 欧美一区二区日韩| 亚洲激情一二三区| 亚洲午夜私人影院| 欧美视频完全免费看| 亚洲免费高清视频在线| 亚洲综合激情另类小说区| 国产欧美一区二区精品久导航| 日韩av不卡在线观看| 久久不见久久见免费视频7| 91国产丝袜在线播放| 久久国内精品自在自线400部| 精品久久久久99| 91国内精品野花午夜精品| 亚洲一区在线播放| 麻豆视频观看网址久久| 久久色在线视频| 欧美体内she精高潮| 日韩视频在线你懂得| 久久奇米777| 91精品国产免费久久综合| 亚洲国产精品99久久久久久久久| 免播放器亚洲一区| 国产一区二区三区综合| 91视频xxxx| 在线播放中文字幕一区| 精品免费国产一区二区三区四区| 国产精品国产自产拍在线| 韩国成人精品a∨在线观看| 93久久精品日日躁夜夜躁欧美| 六月丁香综合在线视频| 色老综合老女人久久久| 国产精品一卡二| 国产河南妇女毛片精品久久久| 蜜桃精品视频在线观看| 91 com成人网| 亚洲欧美日韩人成在线播放| 国产精品对白交换视频 | 国产精品网站在线播放| 久久99精品久久久久久久久久久久| 成人免费毛片高清视频| 久久综合精品国产一区二区三区| 日韩精品专区在线影院观看| 欧美视频一区二区在线观看| 精品久久一区二区| 毛片av一区二区三区| 精品国产乱码久久久久久免费 | 99久久99久久综合| 日本精品一区二区三区高清 | 日韩一区二区在线免费观看| 天堂在线亚洲视频| 欧美一级理论片| 欧美日韩成人在线| 91丨porny丨国产| 日韩欧美一区中文| 日韩亚洲欧美综合| 国产精品白丝av| 日韩欧美另类在线| 一本一本久久a久久精品综合麻豆| 亚洲国产va精品久久久不卡综合| 91成人免费电影| 久久国产福利国产秒拍| 国产精品二三区| 日韩欧美一区二区三区在线| 久久五月婷婷丁香社区|