構建者模式

構建者模式(Builder Pattern)是一種創建型設計模式。該模式通過一步步構建的方式創建複雜對象。在本篇文章中,我們將從以下幾個方面對構建者模式進行詳細的闡述:

一、基本定義

構建者模式的主要思想是將一個複雜對象的構建過程與它的表示分離,從而同樣的構建過程可以變換不同的表示。該模式將對象的構建過程簡單化,用戶無需知道類的內部結構,即可獲取到複雜的對象。


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

二、角色說明

下面介紹構建者模式中的幾個角色:

  • Product(產品):被構建的複雜對象。
  • Builder(構建者):抽象的介面或者抽象類,定義了複雜對象的構建過程。
  • ConcreteBuilder(具體的構建者):實現Builder介面,負責具體的構建過程。
  • Director(指揮者):負責調用Builder介面並構造複雜對象,包含一個Builder引用。

三、使用場景

構建者模式通常應用於以下幾種情況:

  • 需要生產的產品具有複雜的內部結構。
  • 需要生產的產品的構建過程有多種可能性。
  • 需要在不同的情況下構建不同的表示。
  • 需要隱藏複雜對象的創建過程,使得客戶端可以直接操作最終的產品。

四、優缺點

構建者模式的優點包括:

  • 將對象的構建過程與表示分離,使得同樣的構建過程可以得到不同的表示。
  • 隱藏了複雜對象的創建過程,使得客戶端可以直接操作最終的產品。

構建者模式的缺點包括:

  • 需要定義多個Builder類,增加了系統的複雜度。
  • 建造者模式的創建對象是有順序的,所以一旦順序出錯的話,程序將出錯。

五、代碼實現

下面展示一個例子,我們創建一個漢堡店,提供各種不同口味的漢堡,顧客可以自己選擇口感和配料,店鋪會根據顧客的口味構建漢堡,並將最終的漢堡呈現給顧客。

1. Item介面

我們定義一個Item介面,表示可能購買的食品。


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

2. Packing介面

我們再定義一個Packing介面,表示購物袋等包裝材料。


public interface Packing {
   public String pack();
}

3. 容器實現類

我們通過創建實現Packing介面的類 來包裝Item介面。


public class Wrapper implements Packing {

   @Override
   public String pack() {
      return "Wrapper";
   }
}
public class Bottle implements Packing {

   @Override
   public String pack() {
      return "Bottle";
   }
}

4. 漢堡實現類

我們創建一個實現Item介面的抽象類,以便於提供默認的功能


public abstract class Burger implements Item {

   @Override
   public Packing packing() {
      return new Wrapper();
   }

   @Override
   public abstract float price();
}
public abstract class ColdDrink implements Item {

    @Override
    public Packing packing() {
       return new Bottle();
    }

    @Override
    public abstract float price();
}

5. 食品實現類

我們創建擴展Burger和ColdDrink的實體類。


public class VegBurger extends Burger {

    @Override
    public float price() {
       return 25.0f;
    }

    @Override
    public String name() {
       return "Veg Burger";
    }
}
public class ChickenBurger extends Burger {

    @Override
    public float price() {
        return 50.5f;
    }

    @Override
    public String name() {
       return "Chicken Burger";
    }
}
public class Coke extends ColdDrink {

    @Override
    public float price() {
       return 30.0f;
    }

    @Override
    public String name() {
       return "Coke";
    }
}
public class Pepsi extends ColdDrink {

    @Override
    public float price() {
        return 35.0f;
    }

    @Override
    public String name() {
        return "Pepsi";
    }
}

6. Meal類

我們創建一個Meal類,其中包含各種Item,並提供一個計算金額的方法。


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());
      }
   }
}

7. MealBuilder類

我們創建一個MealBuilder類,用於創建不同類型的Meal對象。


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;
    }
}

8. Demo類

我們創建一個Demo類,展示使用MealBuilder的過程。


public class Demo {
    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("\n\nNon-Veg Meal");
        nonVegMeal.showItems();
        System.out.println("Total Cost: " + nonVegMeal.getCost());
    }
}

六、總結

構建者模式的優點是將對象的構建過程與表示分離,使得同樣的構建過程可以得到不同的表示;隱藏了複雜對象的創建過程,用戶無需知道類的內部結構,即可獲取到複雜的對象。而缺點在於需要定義多個Builder類,建造者模式的創建對象是有順序的,所以一旦順序出錯的話,程序將出錯。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/240728.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 12:24
下一篇 2024-12-12 12:24

相關推薦

  • 手機安全模式怎麼解除?

    安全模式是一種手機自身的保護模式,它會禁用第三方應用程序並使用僅限基本系統功能。但有時候,安全模式會使你無法使用手機上的一些重要功能。如果你想解除手機安全模式,可以嘗試以下方法: …

    編程 2025-04-28
  • Qt State Machine與狀態機模式

    本文將介紹Qt State Machine和狀態機模式在Qt中的實現。Qt提供了QStateMachine和QState兩個類,可以方便地實現狀態機模式,並且能有效地處理複雜的、多…

    編程 2025-04-27
  • 顯示C++設計模式

    本文將詳細介紹顯示C++設計模式的概念、類型、優點和代碼實現。 一、概念 C++設計模式是在軟體設計階段定義,用於處理常見問題的可重用解決方案。這些解決方案是經過測試和驗證的,並已…

    編程 2025-04-27
  • Centos7進入單用戶模式的解釋

    本文將介紹如何在Centos7中進入單用戶模式,並從以下幾個方面進行詳細的闡述。 一、Centos7進入單用戶模式的解答 在Centos7中進入單用戶模式需要執行以下步驟: 1. …

    編程 2025-04-27
  • 深入解析PSM模式

    一、PSM模式是什麼 PSM模式,即頁面-狀態-模型模式,是一種前端開發模式。它以頁面為中心,將頁面內的所有狀態和業務邏輯抽象成一個由頁面轉化而來的虛擬狀態機模型,從而將業務邏輯與…

    編程 2025-04-25
  • 授權碼模式與OAuth2.0

    一、什麼是授權碼模式 授權碼模式(Authorization Code Grant Type)是OAuth2.0協議中最常用的授權方式之一,也是最為安全的一種授權方式。授權碼模式的…

    編程 2025-04-24
  • 谷歌瀏覽器深色模式

    一、深色模式的概念 深色模式是一種日益流行的 UI 設計趨勢,通過使用暗灰色或黑色背景,大大降低了屏幕的亮度,更加舒適和護眼。深色模式也被稱為暗黑模式。 谷歌瀏覽器深色模式的推出可…

    編程 2025-04-24
  • 暗黑模式的盛行

    一、背景和定義 暗黑模式起源於智能手錶和夜視儀等專業設備上的配色方案,是指採用黑底白字、暗灰底白字等相對較暗的背景色搭配亮色前景,以減少屏幕對用戶眼睛的刺激,降低視覺疲勞感。這種設…

    編程 2025-04-24
  • 從多個方面詳細闡述MVC模式和三層架構

    一、MVC模式 MVC是Model-View-Controller的縮寫,是一種應用於軟體工程的設計模式。MVC模式將一個軟體應用分為三個基本部分:模型(Model)、視圖(Vie…

    編程 2025-04-24
  • 單例模式的作用

    一、概念解釋 1、單例模式是指一個類只允許存在一個實例對象,且該對象能被系統中其他模塊所共用。該模式主要解決了全局變數的問題,在同一時間只有一個實例被使用,避免了多次重複實例化造成…

    編程 2025-04-23

發表回復

登錄後才能評論