簡單工廠將字串判斷交給了工廠
工廠方法模式不同的工廠建立了不同的產品
接著pizza的例子,假設createpizza()只是得到了pizza,交給客戶之前這個pizza還需要做一些其他的工序,如撒點肉鬆、包裝等(這裡將這些操作統一叫做prepare())。而這些prepare在紐約店和在芝加哥店都是不一樣的。那怎麼辦?抽象工廠**如下:
首先是pizza超類,可以看到擁有乙個保護的 pizza原料工廠和meat。通過整合,所有型別的pizza都應該具有這兩個屬性
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/12.
*/public abstract class pizza
接著是各類pizza
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public class cheesepizza extends pizza
@override
public void prepare()
@override
public void eat()
}
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public class greekpizza extends pizza
@override
public void prepare()
@override
public void eat()
}
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public class hotpizza extends pizza
@override
public void prepare()
@override
public void eat()
}
對比工廠方法模式,可以看到,這裡沒有為不同地方的同型別pizza作區分。每個型別的pizza的構造需要傳遞進去乙個地方的原料工廠,prepare直接呼叫這個地域工廠的方法取得原料meat。下面是meat超類的定義,它只有乙個活的名字的方法name()。
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public abstract class meat
//芝加哥的肉
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public class chicagomeat extends meat
}
//紐約的肉
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public class nymeat extends meat
}
然後是原料工廠超類
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public inte***ce pizzaingredientfactory
//芝加哥的原料工廠
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public class chicagopizzaingredientfactory implements pizzaingredientfactory
}
//紐約的原料工廠
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public class nypizzaingredientfactory implements pizzaingredientfactory
}
接著是pizzastore超類
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/12.
*/public abstract class pizzastore
protected abstract pizza createpizza(string type);
}
//芝加哥pizzastore
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/12.
*/public class chicagopizzastore extends pizzastore else if(type.equals("greek"))else
return pizza;
}}
//紐約pizzastore
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/12.
*/public class nypizzastore extends pizzastore else if(type.equals("greek"))else
return pizza;
}}
可以看到抽象工廠在工廠方法的基礎上,將區域pizza的不同也抽象掉了,沒有了nycheesepizza這樣的東西,將不同地域pizza轉化成了不同地域的工廠。對於這個不同,由於store就是按地域區分的,一次store可以明確的指導該新建**的原料工廠。這樣材料的不同就對客戶封閉了。
最後是主程式
package factory.abstractfactory;
/** * created by sgzhang on 2015/8/13.
*/public class abstractrun
}
抽象工廠模式 抽象工廠模式
抽象工廠模式其實是圍繞了乙個超級工廠建立其他的工廠 可參考工廠模式 這個超級工廠又可以想像成是其他工廠的工廠,這種設計模式是一種建立型模式。在抽象工廠模式中,介面是負責建立乙個相關物件的工廠,不需要顯式指出其類。每個生成的工廠都能按照工廠模式提供物件。意圖提供乙個建立一系列相關或相互依賴物件的介面,...
工廠模式 抽象工廠模式
這裡使用簡單的話來講解工廠模式,不涉及程式設計 什麼是工廠模式呢?我的理解是對抽象介面例項的封裝。假如有乙個介面,有若干的實現類,代表不同的例項。傳統產生物件的方法是直接new乙個出來,對於每個例項都要new,當實現介面的類較多時會很麻煩,並且類的實現也暴露出來了。工廠模式是一種產生物件的模式,使用...
工廠模式 抽象工廠模式
子類父類代換 場景 在不同的條件下,需要建立不同的實現子類時。如網路通訊可以使用tcp udp。可以實現同乙個介面,通過工廠類根據條件 tcp或udp 來例項化不同的子類。這些子類符合黎克特制代換原則。public inte ce tlprotocol public class tcpimpleme...