一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - java設計模式之建造者模式學習

java設計模式之建造者模式學習

2019-10-30 17:08java技術網 JAVA教程

建造者模式(Builder Pattern)主要用于“分步驟構建一個復雜的對象”,在這其中“分步驟”是一個穩定的算法,下面給出了詳細的示例

1 概述
建造者模式(Builder Pattern)主要用于“分步驟構建一個復雜的對象”,在這其中“分步驟”是一個穩定的算法,而復雜對象的各個部分則經常變化。因此, 建造者模式主要用來解決“對象部分”的需求變化。 這樣可以對對象構造的過程進行更加精細的控制。

2 示例
以生產手機為例,每個手機分為屏幕Screen、CPU、Battery?,F在要生產兩種手機,蘋果機和三星。

 蘋果:

 

復制代碼代碼如下:


 package org.scott.builder.before.use;

 

import java.util.ArrayList;
import java.util.List;

/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public class ApplePhone {
    List<String> parts = new ArrayList<String>();

    public void createCPU() {
        parts.add("CUP: Qualcomm");
    }

    public void createScreen() {
        parts.add("SCREEN: JDI");
    }

    public void createBattery() {
        parts.add("BATTERY: DeSai");
    }

    public void show(){
        System.out.print("產品部件信息:");
        for(String part : parts){
            System.out.print(part + "\t");
        }
    }
}
 

 

 三星:

 

復制代碼代碼如下:


 package org.scott.builder.before.use;

 

import java.util.ArrayList;
import java.util.List;

/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public class SamsungPhone {
    List<String> parts = new ArrayList<String>();

    public void createCPU() {
        parts.add("CUP: MTK");
    }

    public void createScreen() {
        parts.add("SCREEN: Samsung");
    }

    public void createBattery() {
        parts.add("BATTERY: DeSai");
    }

    public void show(){
        System.out.print("產品部件信息:");
        for(String part : parts){
            System.out.print(part + "\t");
        }
    }
}
 

 

測試客戶端:

 

復制代碼代碼如下:

package org.scott.builder.before.use;
/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public class BuilerTest {
    private static ApplePhone iphone = new ApplePhone();
    private static SamsungPhone samPhone = new SamsungPhone();

    public static void main(String args[]){
        iphone.createCPU();
        iphone.createScreen();
        iphone.createBattery();
        iphone.show();

        samPhone.createCPU();
        samPhone.createScreen();
        samPhone.createBattery();
        samPhone.show();
    }
}

 

是不是發現個問題?那就是生產手機的每一道工序都是一樣的,確切的說是工序名稱一樣,只是具體的每個工序的處理不同,工序是不變的,就這么幾步,每道工序的具體處理是變化的,由此,我們可以把不變的抽取出來,以“不變應萬變”,將變化的,交給具體的產品來做。
具體怎么做?這回的Builder模式派上用場了。

首先來個Phone的接口:

 

復制代碼代碼如下:


package org.scott.builder.after.use;

 

import java.util.ArrayList;
import java.util.List;

/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public abstract class Phone {
    protected List<String> parts = new ArrayList<String>();

    public void add(String part){
        parts.add(part);
    }

    public void show(){
        System.out.print("產品部件信息:");
        for(String part : parts){
            System.out.print(part + "\t");
        }
    }
}

 

蘋果手機類:

 

復制代碼代碼如下:


package org.scott.builder.after.use;
/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public class ApplePhone extends Phone{

 

}

 

三星手機類:

 

復制代碼代碼如下:


package org.scott.builder.after.use;
/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public class SamsungPhone extends Phone{

 

}

 

再定義個生產步驟的接口Builder:

 

復制代碼代碼如下:

package org.scott.builder.after.use;
/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public interface Builder {
    public void buildCPU();

    public void buildScreen();

    public void buildBattery();

    public Phone getPhone();
}

 

蘋果手機的Builder:

 

復制代碼代碼如下:


package org.scott.builder.after.use;
/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public class ApplePhoneBuilder implements Builder{
    private Phone phone = new ApplePhone();

    @Override
    public void buildCPU() {
        phone.add("CUP: Qualcomm");
    }

 

    @Override
    public void buildScreen() {
        phone.add("SCREEN: JDI");
    }

    @Override
    public void buildBattery() {
        phone.add("BATTERY: DeSai");
    }

    @Override
    public Phone getPhone() {
        return phone;
    }

}

 

三星手機的Builder:

 

復制代碼代碼如下:


package org.scott.builder.after.use;
/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public class SamsungPhoneBuilder implements Builder{

    private Phone phone = new SamsungPhone();

    @Override
    public void buildCPU() {
        phone.add("CUP: MTK");        
    }

 

    @Override
    public void buildScreen() {
        phone.add("SCREEN: Samsung");
    }

    @Override
    public void buildBattery() {
        phone.add("BATTERY: DeSai");        
    }

    @Override
    public Phone getPhone() {
        return phone;
    }

}

 

指導具體生產手機的Director:

 

復制代碼代碼如下:

package org.scott.builder.after.use;
/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public class Director {
    private Builder builder;

    public Director(Builder builder){
        this.builder = builder;
    }

    public void construct(){
        builder.buildCPU();
        builder.buildScreen();
        builder.buildBattery();
    }
}

 

最后寫個測試類:

 

復制代碼代碼如下:


package org.scott.builder.after.use;
/** 
 * @author Scott
 * @version 2013-11-20 
 * @description
 */
public class BuilderTest {

 

    private static Builder iPhoneBuilder = new ApplePhoneBuilder();
    private static Builder samPhoneBuilder  = new SamsungPhoneBuilder();

    public static void main(String[] args) {
        Director director = new Director(iPhoneBuilder);
        director.construct();
        Phone phone = iPhoneBuilder.getPhone();
        System.out.println("iphone");
        phone.show();

        director = new Director(samPhoneBuilder);
        director.construct();
        phone = samPhoneBuilder.getPhone();
        System.out.println("\nsamSung");
        phone.show();
    }

}

 

運行結果:

 

復制代碼代碼如下:

iphone
產品部件信息:CUP: Qualcomm    SCREEN: JDI    BATTERY: DeSai    
samSung
產品部件信息:CUP: MTK    SCREEN: Samsung    BATTERY: DeSai 

 

這里的兩個Phone實體類是空的,如果是這種情況,那么它們可以省略掉,如果 Phone接口也可以被省略掉,最終剩下的就只有 Director、Builder、和具體的 Bulider 實現類。并且,ApplePhone類和 SamsungPhone類是有關系的兩個類,它們不同的手機品牌,如果遇到兩個或多個沒有太多關系的類,公共的接口Phone就沒有存在的必要,但是這時候,那么 Builder 接口的規定的 getPhone() 方法的返回值怎么確定呢?

  無論返回值類型是 ApplePhone還是SamsungPhone,都會產生問題,因為返回結果的類型不統一。此時,可以將 Phone定義成一個空接口(不包含任何方法的接口),再讓這些沒有相互關系的具體產品類都去實現這個接口,那么 Builder 接口里面規定的 getPhone() 方法的返回值類型依然是 Phone 類型,就解決問題了。不過這種情況下,也就沒有使用Builder模式的必要了。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天天做天天爽 | 国产一区二区精品 | 国内精品视频一区二区三区八戒 | www.日本在线播放 | a毛片久久免费观看 | 国产日韩欧美在线观看不卡 | 欧美在线视频一区在线观看 | 欧美一级特黄特色大片免费 | 10个免费货源网站 | 欠操h| 亚洲 欧美 在线观看 | japanese乱子mate | 亚洲123区| 爱福利视频一区二区 | 欧美一区二区三区四区视频 | 国产精品久久久久久久久99热 | 男同互操 | 国产精品久久久久久福利 | 欧美成人aa久久狼窝动画 | 日本老头4569gay | 国产高清在线观看 | 1024香蕉视频| 国产成人综合网 | 免费国产白棉袜踩踏区域 | 欧美一二区视频 | 欧美激情精品久久久久久不卡 | 美女脱得一二净无内裤全身的照片 | 蜜桃视频一区二区 | 加勒比一本大道香蕉在线视频 | 外女思春台湾三级 | 国产精品性视频免费播放 | 免费aⅴ在线 | 日韩在线一区二区 | 亚洲色图欧美色 | japan在线观看 | 女八把屁股扒开让男生添 | 蜜桃成熟3在线观看 | 亚洲视屏在线观看 | 免费一级国产大片 | 秋霞黄色网 | yellow视频免费观看播放 |