サマリー:原理工廠(chǎng)模式主要是為創(chuàng)建對(duì)象提供過(guò)渡接口,以便將創(chuàng)建對(duì)象的具體過(guò)程屏蔽隔離起來(lái),達(dá)到提高靈活性的目的。 模式分類(lèi)工廠(chǎng)模式可以分為三類(lèi): 1)簡(jiǎn)單工廠(chǎng)模式(Simple Factory) 2)工廠(chǎng)方法模式(Factory Method) 3)抽象工廠(chǎng)模式(Abstract Factory) 工廠(chǎng)方法模式:一個(gè)抽象產(chǎn)品類(lèi),可以派生出多個(gè)具體產(chǎn)品類(lèi)。 &
原理
工廠(chǎng)模式主要是為創(chuàng)建對(duì)象提供過(guò)渡接口,以便將創(chuàng)建對(duì)象的具體過(guò)程屏蔽隔離起來(lái),達(dá)到提高靈活性的目的。
模式分類(lèi)
工廠(chǎng)模式可以分為三類(lèi):
1)簡(jiǎn)單工廠(chǎng)模式(Simple Factory)
2)工廠(chǎng)方法模式(Factory Method)
3)抽象工廠(chǎng)模式(Abstract Factory)
工廠(chǎng)方法模式:
一個(gè)抽象產(chǎn)品類(lèi),可以派生出多個(gè)具體產(chǎn)品類(lèi)。
一個(gè)抽象工廠(chǎng)類(lèi),可以派生出多個(gè)具體工廠(chǎng)類(lèi)。
每個(gè)具體工廠(chǎng)類(lèi)只能創(chuàng)建一個(gè)具體產(chǎn)品類(lèi)的實(shí)例。
抽象工廠(chǎng)模式:
多個(gè)抽象產(chǎn)品類(lèi),每個(gè)抽象產(chǎn)品類(lèi)可以派生出多個(gè)具體產(chǎn)品類(lèi)。
一個(gè)抽象工廠(chǎng)類(lèi),可以派生出多個(gè)具體工廠(chǎng)類(lèi)。
每個(gè)具體工廠(chǎng)類(lèi)可以創(chuàng)建多個(gè)具體產(chǎn)品類(lèi)的實(shí)例。
區(qū)別:
工廠(chǎng)方法模式只有一個(gè)抽象產(chǎn)品類(lèi),而抽象工廠(chǎng)模式有多個(gè)。
工廠(chǎng)方法模式的具體工廠(chǎng)類(lèi)只能創(chuàng)建一個(gè)具體產(chǎn)品類(lèi)的實(shí)例,而抽象工廠(chǎng)模式可以創(chuàng)建多個(gè)。兩者皆可。
簡(jiǎn)單工廠(chǎng)模式
簡(jiǎn)單工廠(chǎng)模式又稱(chēng)靜態(tài)工廠(chǎng)方法模式。它存在的目的很簡(jiǎn)單:定義一個(gè)用于創(chuàng)建對(duì)象的接口。
先來(lái)看看它的組成:
1) 工廠(chǎng)類(lèi)角色:這是本模式的核心,含有一定的商業(yè)邏輯和判斷邏輯。
2) 抽象產(chǎn)品角色:它一般是具體產(chǎn)品繼承的父類(lèi)或者實(shí)現(xiàn)的接口。
3) 具體產(chǎn)品角色:工廠(chǎng)類(lèi)所創(chuàng)建的對(duì)象就是此角色的實(shí)例。
下面我們從開(kāi)閉原則(對(duì)擴(kuò)展開(kāi)放;對(duì)修改封閉)上來(lái)分析下簡(jiǎn)單工廠(chǎng)模式。當(dāng)客戶(hù)不再滿(mǎn)足現(xiàn)有的車(chē)型號(hào)的時(shí)候,想要一種速度快的新型車(chē),只要這種車(chē)符合抽象產(chǎn)品制定的合同,那么只要通知工廠(chǎng)類(lèi)知道就可以被客戶(hù)使用了。所以對(duì)產(chǎn)品部分來(lái)說(shuō),它是符合開(kāi)閉原則的;但是工廠(chǎng)部分好像不太理想,因?yàn)槊吭黾右环N新型車(chē),都要在工廠(chǎng)類(lèi)中增加相應(yīng)的創(chuàng)建業(yè)務(wù)邏輯(createBMW(type)方法需要新增case),這顯然是違背開(kāi)閉原則的。可想而知對(duì)于新產(chǎn)品的加入,工廠(chǎng)類(lèi)是很被動(dòng)的。對(duì)于這樣的工廠(chǎng)類(lèi),我們稱(chēng)它為全能類(lèi)或者上帝類(lèi)。
我們舉的例子是最簡(jiǎn)單的情況,而在實(shí)際應(yīng)用中,很可能產(chǎn)品是一個(gè)多層次的樹(shù)狀結(jié)構(gòu)。由于簡(jiǎn)單工廠(chǎng)模式中只有一個(gè)工廠(chǎng)類(lèi)來(lái)對(duì)應(yīng)這些產(chǎn)品,所以這可能會(huì)把我們的上帝累壞了。
于是工廠(chǎng)方法模式作為救世主出現(xiàn)了,工廠(chǎng)類(lèi)定義成了接口,而每新增的車(chē)種類(lèi)型,就增加該車(chē)種類(lèi)型對(duì)應(yīng)工廠(chǎng)類(lèi)的實(shí)現(xiàn),這樣工廠(chǎng)的設(shè)計(jì)就可以擴(kuò)展了,而不必去修改原來(lái)的代碼。
工廠(chǎng)方法模式
工廠(chǎng)方法模式去掉了簡(jiǎn)單工廠(chǎng)模式中工廠(chǎng)方法的靜態(tài)屬(type),使得它可以被子類(lèi)繼承。這樣在簡(jiǎn)單工廠(chǎng)模式里集中在工廠(chǎng)方法上的壓力可以由工廠(chǎng)方法模式里不同的工廠(chǎng)子類(lèi)來(lái)分擔(dān)。
工廠(chǎng)方法模式組成:
1)抽象工廠(chǎng)角色: 這是工廠(chǎng)方法模式的核心,它與應(yīng)用程序無(wú)關(guān)。是具體工廠(chǎng)角色必須實(shí)現(xiàn)的接口或者必須繼承的父類(lèi)。
2)具體工廠(chǎng)角色:它含有和具體業(yè)務(wù)邏輯有關(guān)的代碼。由應(yīng)用程序調(diào)用以創(chuàng)建對(duì)應(yīng)的具體產(chǎn)品的對(duì)象。
3)抽象產(chǎn)品角色:它是具體產(chǎn)品繼承的父類(lèi)或者是實(shí)現(xiàn)的接口。在java中一般有抽象類(lèi)或者接口來(lái)實(shí)現(xiàn)。
4)具體產(chǎn)品角色:具體工廠(chǎng)角色所創(chuàng)建的對(duì)象就是此角色的實(shí)例。在java中由具體的類(lèi)來(lái)實(shí)現(xiàn)。
可以看出工廠(chǎng)方法的加入,使得對(duì)象的數(shù)量成倍增長(zhǎng)。當(dāng)產(chǎn)品種類(lèi)非常多時(shí),會(huì)出現(xiàn)大量的與之對(duì)應(yīng)的工廠(chǎng)對(duì)象,這不是我們所希望的。因?yàn)槿绻荒鼙苊膺@種情 況,可以考慮使用簡(jiǎn)單工廠(chǎng)模式與工廠(chǎng)方法模式相結(jié)合的方式來(lái)減少工廠(chǎng)類(lèi):即對(duì)于產(chǎn)品樹(shù)上類(lèi)似的種類(lèi)(一般是樹(shù)的葉子中互為兄弟的)使用簡(jiǎn)單工廠(chǎng)模式來(lái)實(shí) 現(xiàn)。
抽象工廠(chǎng)模式
抽象工廠(chǎng)模式和工廠(chǎng)方法模式的區(qū)別就在于需要?jiǎng)?chuàng)建對(duì)象的復(fù)雜程度上。而且抽象工廠(chǎng)模式是三個(gè)里面最為抽象、最具一般性的。
抽象工廠(chǎng)模式的用意為:給客戶(hù)端提供一個(gè)接口,可以創(chuàng)建多個(gè)產(chǎn)品族中的產(chǎn)品對(duì)象。
抽象工廠(chǎng)模式的各個(gè)角色(和工廠(chǎng)方法一樣):
1)抽象工廠(chǎng)角色: 這是工廠(chǎng)方法模式的核心,它與應(yīng)用程序無(wú)關(guān)。是具體工廠(chǎng)角色必須實(shí)現(xiàn)的接口或者必須繼承的父類(lèi)。
2)具體工廠(chǎng)角色:它含有和具體業(yè)務(wù)邏輯有關(guān)的代碼。由應(yīng)用程序調(diào)用以創(chuàng)建對(duì)應(yīng)的具體產(chǎn)品的對(duì)象。
3)抽象產(chǎn)品角色:它是具體產(chǎn)品繼承的父類(lèi)或者是實(shí)現(xiàn)的接口。
4)具體產(chǎn)品角色:具體工廠(chǎng)角色所創(chuàng)建的對(duì)象就是此角色的實(shí)例。