類型:創建類模式
類圖:
抽象工廠模式與工廠方法模式的區分
抽象工廠模式是工廠方法模式的升級版本,他用來創建1組相干或相互依賴的對象。他與工廠方法模式的區分就在于,工廠方法模式針對的是1個產品等級結構;而抽象工廠模式則是針對的多個產品等級結構。在編程中,通常1個產品結構,表現為1個接口或抽象類,也就是說,工廠方法模式提供的所有產品都是衍生自同1個接口或抽象類,而抽象工廠模式所提供的產品則是衍生自不同的接口或抽象類。
在抽象工廠模式中,有1個產品族的概念:所謂的產品族,是指位于不同產品等級結構中功能相干聯的產品組成的家族。抽象工廠模式所提供的1系列產品就組成1個產品族;而工廠方法提供的1系列產品稱為1個等級結構。我們仍然拿生產汽車的例子來講明他們之間的區分。
在上面的類圖中,兩廂車和3廂車稱為兩個不同的等級結構;而2.0排量車和2.4排量車則稱為兩個不同的產品族。再具體1點,2.0排量兩廂車和2.4排量兩廂車屬于同1個等級結構,2.0排量3廂車和2.4排量3廂車屬于另外一個等級結構;而2.0排量兩廂車和2.0排量3廂車屬于同1個產品族,2.4排量兩廂車和2.4排量3廂車屬于另外一個產品族。
明白了等級結構和產品族的概念,就理解工廠方法模式和抽象工廠模式的區分了,如果工廠的產品全部屬于同1個等級結構,則屬于工廠方法模式;如果工廠的產品來自多個等級結構,則屬于抽象工廠模式。在本例中,如果1個工廠模式提供2.0排量兩廂車和2.4排量兩廂車,那末他屬于工廠方法模式;如果1個工廠模式是提供2.4排量兩廂車和2.4排量3廂車兩個產品,那末這個工廠模式就是抽象工廠模式,由于他提供的產品是分屬兩個不同的等級結構。固然,如果1個工廠提供全部4種車型的產品,由于產品分屬兩個等級結構,他固然也屬于抽象工廠模式了。
抽象工廠模式代碼
抽象工廠模式的優點
抽象工廠模式除具有工廠方法模式的優點外,最主要的優點就是可以在類的內部對產品族進行束縛。所謂的產品族,1般或多或少的都存在1定的關聯,抽象工廠模式就能夠在類內部對產品族的關聯關系進行定義和描寫,而沒必要專門引入1個新的類來進行管理。
抽象工廠模式的缺點
產品族的擴大將是1件10分費力的事情,假設產品族中需要增加1個新的產品,則幾近所有的工廠類都需要進行修改。所以使用抽象工廠模式時,對產品等級結構的劃分是非常重要的。
適用處景
當需要創建的對象是1系列相互關聯或相互依賴的產品族時,即可以使用抽象工廠模式。說的更明白1點,就是1個繼承體系中,如果存在著多個等級結構(即存在著多個抽象類),并且分屬各個等級結構中的實現類之間存在著1定的關聯或束縛,就能夠使用抽象工廠模式。假設各個等級結構中的實現類之間不存在關聯或束縛,則使用多個獨立的工廠來對產品進行創建,則更適合1點。
總結
不管是簡單工廠模式,工廠方法模式,還是抽象工廠模式,他們都屬于工廠模式,在情勢和特點上也是極其相似的,他們的終究目的都是為了解耦。在使用時,我們沒必要去在乎這個模式到底工廠方法模式還是抽象工廠模式,由于他們之間的演化常常是使人揣摩不透的。常常你會發現,明明使用的工廠方法模式,當新需求來臨,略加修改,加入了1個新方法后,由于類中的產品構成了不同等級結構中的產品族,它就變成抽象工廠模式了;而對抽象工廠模式,當減少1個方法使的提供的產品不再構成產品族以后,它就演化成了工廠方法模式。
所以,在使用工廠模式時,只需要關心下降耦合度的目的是不是到達了。