资讯专栏INFORMATION COLUMN

Design Patterns - Builder Pattern(译)

Pikachu / 2699人阅读

摘要:第七步使用来演示生成器模式第八步校验输出译者注注意区分抽象工厂模式和生成器模式的区别生成器模式的是生产一个复杂的产品,抽象工厂模式是生产一个族的产品。具体请参考文章生成器模式与抽象工厂模式的区别。

原文链接
译者:smallclover
个人翻译,水平有限,如有错误欢迎指出,谢谢!

设计模式-生成器模式

生成器模式使用简单的对象来逐步的构建一个复杂的对象。这种类型的设计模式是创建型模式中创建对象最好的方式之一。
一个生成器类会逐步的构建这个最终的对象。这个生成器与其他对象是相互独立的。

实现

我们举一个快餐店的案例:这个快餐店的典型饮食风格是一个汉堡加一杯可乐。这里的汉堡可以是蔬菜汉堡也可以是鸡肉汉堡,它们将使用包装纸来包装;冷饮可以是可口可乐或者是百事可乐,它们将使用瓶子来包装。
我们将创建一个Item接口代表食品元素如汉堡和冷饮,创建具体的类实现这个Item接口;Packing接口代表包装食品元素,创建具体的类实现这个Packing接口,像汉堡可以通过包装纸来包装,冷饮可以通过瓶子来包装。
我们随后将创建一个Meal类,它有一个存储Item类型的ArrayList,然后我们使用一个MealBuilder来结合Item来构建不同类型的Meal对象。BuilderPatternDemo,我们的demo类将使用MealBuilder将会构建一个Meal

第一步

创建一个接口Item代表食品元素和一个Packing接口代表包装的情况。
Item.java

public interface Item {
   public String name();
   public Packing packing();
   public float price();    
}

Packing.java

public interface Packing {
   public String pack();
}
第二步

创建具体的类来实现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";
   }
}
第三步

创建多个抽象类实现Item接口提供默认的功能。
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();
}
第三步

创建具体的类继承BurgerColdDrink类。
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";
   }
}
第五步

创建一个Meal类,该类包含一个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

第六步

创建一个MealBuilder类,这个类负责实际创建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());
   }
}
第八步

校验输出

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
译者注

注意区分抽象工厂模式和生成器模式的区别:生成器模式的是生产一个复杂的产品,抽象工厂模式是生产一个族的产品。具体请参考文章生成器模式与抽象工厂模式的区别。若无法理解请自行Google,这里只做简单的介绍。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/65683.html

相关文章

  • Design Patterns-Command Pattern

    摘要:调用者对象会寻找合适的并且能够处理该命令的对象,然后把该命令传递给相应的对象处理。紧接着创建一个类代表请求。创建具体的命令类和实现接口,它们将会作为具体的命令被处理。代表调用者,它能获得并且发出命令。 原文连接译者 smallclover希望对大家有所帮助。谢谢!(●◡●) 设计模式-命令模式 命令模式是一种数据驱动的设计模式,属于行为型模式这一类。命令模式会将一个请求包装成一个对象并...

    ACb0y 评论0 收藏0
  • Design Patterns - Proxy Pattern

    摘要:在代理模式中,我们将创建一个对象,该对象在在接口中持有原始对象,以对外部提供它的功能。实现我们将创建一个接口并且创建具体类实现接口。 原文链接译者:smallclover希望对你们有所帮助,谢谢阅读! 设计模式-代理模式 在代理模式中,我们使用一个类来代表另一个类的功能。这种类型的设计模式属于结构型设计模式的一种。在代理模式中,我们将创建一个对象,该对象在在接口中持有原始对象,以对外部...

    mtunique 评论0 收藏0
  • Design Patterns - Facade Pattern

    摘要:实现我们将创建一个接口,并且创建具体的类实现它。接下来我们需要声明一个门面类。,我们的类将通过使用类来展示这些结果。 原文链接译者:smallclover希望对大家有所帮助!Thanks for your watching 门面模式 门面模式隐藏系统的复杂性同时会提供一个接口给用户,使得用户可以使用该系统。这种类型的设计模式属于结构型模式的一种,它将会添加一个接口到现有的系统当中,用户...

    nihao 评论0 收藏0
  • Design Patterns - Iterator Pattern

    摘要:迭代器模式属于行为型模式下的一种。实现我们将创建一个接口,该接口描述迭代所需要的方法紧接着声明了一个接口,该接口返回一个对象。我们会创建具体的类实现接口和接口,并去使用它们。第三步使用获得迭代器并且打印。 原文地址译者 smallclover希望对你们有所帮助 设计模式-迭代器模式 迭代器是Java和.Net程序环境下经常使用的一种设计模式。这种设计模式通常用来获取能顺序访问集合对元素...

    Tony_Zby 评论0 收藏0
  • Design Patterns - Decorator Pattern

    摘要:然后在创建一个抽象的类,该类也实现了接口,并且持有一个类的对象。第四步创建具体的装饰器类,该类继承了类。第五步使用装饰对象。 原文链接译者:smallclover个人翻译,因为英语水平的原因可能会词不达意,十分欢迎各位读者指出其中的错误,希望能对读者有1%的用处,谢谢! 设计模式-装饰器模式 装饰器模式允许使用者将新功能添加到现有的对象而不需要改变它的数据结构。这种类型的设计模式来源于...

    宠来也 评论0 收藏0

发表评论

0条评论

Pikachu

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<