抽象工廠模式

2021-07-04 13:25:34 字數 3458 閱讀 5708

簡單工廠將字串判斷交給了工廠

工廠方法模式不同的工廠建立了不同的產品

接著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...