摘要:第七步使用來演示生成器模式第八步校驗(yàn)輸出譯者注注意區(qū)分抽象工廠模式和生成器模式的區(qū)別生成器模式的是生產(chǎn)一個(gè)復(fù)雜的產(chǎn)品,抽象工廠模式是生產(chǎn)一個(gè)族的產(chǎn)品。具體請參考文章生成器模式與抽象工廠模式的區(qū)別。
設(shè)計(jì)模式-生成器模式原文鏈接
譯者:smallclover
個(gè)人翻譯,水平有限,如有錯(cuò)誤歡迎指出,謝謝!
生成器模式使用簡單的對象來逐步的構(gòu)建一個(gè)復(fù)雜的對象。這種類型的設(shè)計(jì)模式是創(chuàng)建型模式中創(chuàng)建對象最好的方式之一。
一個(gè)生成器類會(huì)逐步的構(gòu)建這個(gè)最終的對象。這個(gè)生成器與其他對象是相互獨(dú)立的。
我們舉一個(gè)快餐店的案例:這個(gè)快餐店的典型飲食風(fēng)格是一個(gè)漢堡加一杯可樂。這里的漢堡可以是蔬菜漢堡也可以是雞肉漢堡,它們將使用包裝紙來包裝;冷飲可以是可口可樂或者是百事可樂,它們將使用瓶子來包裝。
我們將創(chuàng)建一個(gè)Item接口代表食品元素如漢堡和冷飲,創(chuàng)建具體的類實(shí)現(xiàn)這個(gè)Item接口;Packing接口代表包裝食品元素,創(chuàng)建具體的類實(shí)現(xiàn)這個(gè)Packing接口,像漢堡可以通過包裝紙來包裝,冷飲可以通過瓶子來包裝。
我們隨后將創(chuàng)建一個(gè)Meal類,它有一個(gè)存儲(chǔ)Item類型的ArrayList,然后我們使用一個(gè)MealBuilder來結(jié)合Item來構(gòu)建不同類型的Meal對象。BuilderPatternDemo,我們的demo類將使用MealBuilder將會(huì)構(gòu)建一個(gè)Meal。
創(chuàng)建一個(gè)接口Item代表食品元素和一個(gè)Packing接口代表包裝的情況。
Item.java
public interface Item { public String name(); public Packing packing(); public float price(); }
Packing.java
public interface Packing { public String pack(); }第二步
創(chuàng)建具體的類來實(shí)現(xiàn)Packing 接口。
Wrapper.java
public class Wrapper implements Packing { @Override public String pack() { return "Wrapper"; } }
Bottle.java
public class Bottle implements Packing { @Override public String pack() { return "Bottle"; } }第三步
創(chuàng)建多個(gè)抽象類實(shí)現(xiàn)Item接口提供默認(rèn)的功能。
Burger.java
public abstract class Burger implements Item { @Override public Packing packing() { return new Wrapper(); } @Override public abstract float price(); }
ColdDrink.java
public abstract class ColdDrink implements Item { @Override public Packing packing() { return new Bottle(); } @Override public abstract float price(); }第三步
創(chuàng)建具體的類繼承Burger和ColdDrink類。
VegBurger.java
public class VegBurger extends Burger { @Override public float price() { return 25.0f; } @Override public String name() { return "Veg Burger"; } }
ChickenBurger.java
public class ChickenBurger extends Burger { @Override public float price() { return 50.5f; } @Override public String name() { return "Chicken Burger"; } }
Coke.java
public class Coke extends ColdDrink { @Override public float price() { return 30.0f; } @Override public String name() { return "Coke"; } }
Pepsi.java
public class Pepsi extends ColdDrink { @Override public float price() { return 35.0f; } @Override public String name() { return "Pepsi"; } }第五步
創(chuàng)建一個(gè)Meal類,該類包含一個(gè)Item的集合。
Meal.java
import java.util.ArrayList; import java.util.List; public class Meal { private List- items = new ArrayList
- (); public void addItem(Item item){ items.add(item); } public float getCost(){ float cost = 0.0f; for (Item item : items) { cost += item.price(); } return cost; } public void showItems(){ for (Item item : items) { System.out.print("Item : " + item.name()); System.out.print(", Packing : " + item.packing().pack()); System.out.println(", Price : " + item.price()); } } }
Step 6
第六步創(chuàng)建一個(gè)MealBuilder類,這個(gè)類負(fù)責(zé)實(shí)際創(chuàng)建Meal對象。
MealBuilder.java
public class MealBuilder { public Meal prepareVegMeal (){ Meal meal = new Meal(); meal.addItem(new VegBurger()); meal.addItem(new Coke()); return meal; } public Meal prepareNonVegMeal (){ Meal meal = new Meal(); meal.addItem(new ChickenBurger()); meal.addItem(new Pepsi()); return meal; } }第七步
BuilderPatternDemo使用MealBuilder來演示生成器模式
BuilderPatternDemo.java
public class BuilderPatternDemo { public static void main(String[] args) { MealBuilder mealBuilder = new MealBuilder(); Meal vegMeal = mealBuilder.prepareVegMeal(); System.out.println("Veg Meal"); vegMeal.showItems(); System.out.println("Total Cost: " + vegMeal.getCost()); Meal nonVegMeal = mealBuilder.prepareNonVegMeal(); System.out.println(" Non-Veg Meal"); nonVegMeal.showItems(); System.out.println("Total Cost: " + nonVegMeal.getCost()); } }第八步
校驗(yàn)輸出
Veg Meal Item : Veg Burger, Packing : Wrapper, Price : 25.0 Item : Coke, Packing : Bottle, Price : 30.0 Total Cost: 55.0 Non-Veg Meal Item : Chicken Burger, Packing : Wrapper, Price : 50.5 Item : Pepsi, Packing : Bottle, Price : 35.0 Total Cost: 85.5譯者注
注意區(qū)分抽象工廠模式和生成器模式的區(qū)別:生成器模式的是生產(chǎn)一個(gè)復(fù)雜的產(chǎn)品,抽象工廠模式是生產(chǎn)一個(gè)族的產(chǎn)品。具體請參考文章生成器模式與抽象工廠模式的區(qū)別。若無法理解請自行Google,這里只做簡單的介紹。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/65683.html
摘要:調(diào)用者對象會(huì)尋找合適的并且能夠處理該命令的對象,然后把該命令傳遞給相應(yīng)的對象處理。緊接著創(chuàng)建一個(gè)類代表請求。創(chuàng)建具體的命令類和實(shí)現(xiàn)接口,它們將會(huì)作為具體的命令被處理。代表調(diào)用者,它能獲得并且發(fā)出命令。 原文連接譯者 smallclover希望對大家有所幫助。謝謝!(●?●) 設(shè)計(jì)模式-命令模式 命令模式是一種數(shù)據(jù)驅(qū)動(dòng)的設(shè)計(jì)模式,屬于行為型模式這一類。命令模式會(huì)將一個(gè)請求包裝成一個(gè)對象并...
摘要:在代理模式中,我們將創(chuàng)建一個(gè)對象,該對象在在接口中持有原始對象,以對外部提供它的功能。實(shí)現(xiàn)我們將創(chuàng)建一個(gè)接口并且創(chuàng)建具體類實(shí)現(xiàn)接口。 原文鏈接譯者:smallclover希望對你們有所幫助,謝謝閱讀! 設(shè)計(jì)模式-代理模式 在代理模式中,我們使用一個(gè)類來代表另一個(gè)類的功能。這種類型的設(shè)計(jì)模式屬于結(jié)構(gòu)型設(shè)計(jì)模式的一種。在代理模式中,我們將創(chuàng)建一個(gè)對象,該對象在在接口中持有原始對象,以對外部...
摘要:實(shí)現(xiàn)我們將創(chuàng)建一個(gè)接口,并且創(chuàng)建具體的類實(shí)現(xiàn)它。接下來我們需要聲明一個(gè)門面類。,我們的類將通過使用類來展示這些結(jié)果。 原文鏈接譯者:smallclover希望對大家有所幫助!Thanks for your watching 門面模式 門面模式隱藏系統(tǒng)的復(fù)雜性同時(shí)會(huì)提供一個(gè)接口給用戶,使得用戶可以使用該系統(tǒng)。這種類型的設(shè)計(jì)模式屬于結(jié)構(gòu)型模式的一種,它將會(huì)添加一個(gè)接口到現(xiàn)有的系統(tǒng)當(dāng)中,用戶...
摘要:迭代器模式屬于行為型模式下的一種。實(shí)現(xiàn)我們將創(chuàng)建一個(gè)接口,該接口描述迭代所需要的方法緊接著聲明了一個(gè)接口,該接口返回一個(gè)對象。我們會(huì)創(chuàng)建具體的類實(shí)現(xiàn)接口和接口,并去使用它們。第三步使用獲得迭代器并且打印。 原文地址譯者 smallclover希望對你們有所幫助 設(shè)計(jì)模式-迭代器模式 迭代器是Java和.Net程序環(huán)境下經(jīng)常使用的一種設(shè)計(jì)模式。這種設(shè)計(jì)模式通常用來獲取能順序訪問集合對元素...
摘要:然后在創(chuàng)建一個(gè)抽象的類,該類也實(shí)現(xiàn)了接口,并且持有一個(gè)類的對象。第四步創(chuàng)建具體的裝飾器類,該類繼承了類。第五步使用裝飾對象。 原文鏈接譯者:smallclover個(gè)人翻譯,因?yàn)橛⒄Z水平的原因可能會(huì)詞不達(dá)意,十分歡迎各位讀者指出其中的錯(cuò)誤,希望能對讀者有1%的用處,謝謝! 設(shè)計(jì)模式-裝飾器模式 裝飾器模式允許使用者將新功能添加到現(xiàn)有的對象而不需要改變它的數(shù)據(jù)結(jié)構(gòu)。這種類型的設(shè)計(jì)模式來源于...
閱讀 838·2021-11-25 09:43
閱讀 1713·2021-09-29 09:42
閱讀 1921·2019-08-30 15:55
閱讀 3441·2019-08-30 15:54
閱讀 2644·2019-08-30 13:20
閱讀 3531·2019-08-29 13:25
閱讀 949·2019-08-28 18:03
閱讀 1808·2019-08-26 13:44