現(xiàn)在進(jìn)入下一個(gè)分類。
類型2:結(jié)構(gòu) - 裝飾者設(shè)計(jì)模式
我將為您提供一個(gè)小場(chǎng)景,以便更好地說(shuō)明為什么以及在何處使用裝飾器模式。
假設(shè)你擁有一家咖啡店,像任何新手一樣,你從兩種普通咖啡開始,即家庭混合咖啡和深色烘焙咖啡。在您的計(jì)費(fèi)系統(tǒng)中,有一個(gè)用于不同咖啡混合的類,該類繼承了飲料抽象類。人們實(shí)際上開始過(guò)來(lái)喝你的美妙(盡管很苦?)咖啡。然后是咖啡新手,上帝保佑,他們想要糖或牛奶??Х日媸翘爸S了!!??
現(xiàn)在,您還需要將這兩個(gè)附加組件也放在菜單上,不幸的是,在計(jì)費(fèi)系統(tǒng)上。最初,您的IT人員將為兩種咖啡制作一個(gè)子類,一種包括糖,另一種包括牛奶。然后,既然客戶總是對(duì)的,人們會(huì)說(shuō)這些可怕的話:
“我能喝點(diǎn)加糖的牛奶咖啡嗎?”
???
你的計(jì)費(fèi)系統(tǒng)再次在你的臉上笑了起來(lái)。好吧,回到繪圖板.
然后,IT 人員將含糖的牛奶咖啡作為另一個(gè)子類添加到每個(gè)父咖啡類中。這個(gè)月剩下的時(shí)間一帆風(fēng)順,人們排隊(duì)喝咖啡,你實(shí)際上賺錢了。??
但是,等等,還有更多!
世界再次與你作對(duì)。一個(gè)競(jìng)爭(zhēng)對(duì)手在街對(duì)面打開,不僅有4種咖啡,還有10多種附加組件!
你買了所有這些甚至更多,自己賣更好的咖啡,然后記住你忘了更新那個(gè)沉悶的計(jì)費(fèi)系統(tǒng)。您很可能無(wú)法為所有附加組件的任何和所有組合制作無(wú)限數(shù)量的子類,也可以使用新的咖啡混合物。更不用說(shuō)最終系統(tǒng)的大小了。
是時(shí)候?qū)嶋H投資適當(dāng)?shù)挠?jì)費(fèi)系統(tǒng)了。你找到新的IT人員,他們實(shí)際上知道他們?cè)谧鍪裁矗麄冋f(shuō),
“為什么,如果它使用裝飾器圖案,這將變得容易得多,也更小。
那到底是什么?
裝飾器設(shè)計(jì)模式屬于結(jié)構(gòu)類別,該類別處理類的實(shí)際結(jié)構(gòu),無(wú)論是通過(guò)繼承,組合還是兩者兼而有之。此設(shè)計(jì)的目標(biāo)是在運(yùn)行時(shí)修改對(duì)象的功能。這是許多其他設(shè)計(jì)模式之一,它們利用抽象類和具有組合的接口來(lái)獲得所需的結(jié)果。
讓我們給數(shù)學(xué)一個(gè)機(jī)會(huì)(不寒而栗?),把這一切帶入視角。
取 4 種混合咖啡和 10 種附加組件。如果我們堅(jiān)持為一種咖啡的所有附加組件的每個(gè)不同組合生成子類。那是:
(10–1)² = 9² = 81 個(gè)子類
我們從10中減去1,因?yàn)槟悴荒軐⒁粋€(gè)附加組件與另一個(gè)相同類型的附加組件組合在一起,糖與糖聽起來(lái)很愚蠢。而這只適用于一種咖啡混合物。將81乘以4,你會(huì)得到一個(gè)驚人的324個(gè)不同的子類!談?wù)撍羞@些編碼...
但是對(duì)于裝飾器模式,在這種情況下,它只需要16個(gè)類。想下注嗎?
裝飾器設(shè)計(jì)模式類圖
根據(jù)咖啡店場(chǎng)景的類圖
如果我們根據(jù)上面的類圖繪制我們的場(chǎng)景,我們將得到4個(gè)咖啡混合物的4個(gè)類,每個(gè)附加組件10個(gè),抽象組件1個(gè),抽象裝飾器1個(gè)。看!260 億現(xiàn)在交出那100美元.??(jk,但如果給予,它不會(huì)被拒絕...只是說(shuō))
從上面可以看出,正如具體的咖啡混合物是飲料抽象類的子類一樣,AddOn抽象類也從它繼承了它的方法。附加組件(即其子類)依次繼承任何新方法,以便在需要時(shí)向基對(duì)象添加功能。
讓我們開始編碼,看看這個(gè)模式在使用中。
首先制作抽象飲料類,所有不同的咖啡混合物將繼承自:
然后添加兩個(gè)具體的咖啡混合類。
AddOn 抽象類也繼承自飲料抽象類(下面將對(duì)此進(jìn)行詳細(xì)介紹)。
現(xiàn)在是這個(gè)抽象類的具體實(shí)現(xiàn):
如您在上面看到的,我們可以將飲料的任何子類傳遞給AddOn的任何子類,并獲得額外的成本以及更新的描述。而且,由于 AddOn 類本質(zhì)上是飲料類型,我們可以將一個(gè)插件傳遞到另一個(gè)插件中。通過(guò)這種方式,我們可以將任意數(shù)量的附加組件添加到特定的咖啡混合物中。
現(xiàn)在編寫一些代碼來(lái)測(cè)試它。
最終結(jié)果是:
它的工作原理!我們能夠向咖啡混合物添加多個(gè)附加組件,并成功更新其最終成本和描述,而無(wú)需為所有咖啡混合物的每個(gè)附加組合制作無(wú)限的子類。