<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-126  評論-247  文章-5  trackbacks-0

    Builder 模式 —— 建造者模式(又譯成生成器模式的主要功能是構建復雜的產品,它是將一個復雜對象的構建與它的表示分離,使得同樣的構建過程可以創建不同的表示。

    舉個例子,打個生產電腦的比方,這里簡單一點,假設生產電腦只需要 CUP、內存和顯卡,現在需要生產宏基和戴爾兩個品牌的電腦,不用設計模式的實現:

    Acer.java

    import java.util.ArrayList;
    import java.util.List;
    /**
     * -----------------------------------------
     * @描述  生產宏基筆記本電腦
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-4 <p>
     * -----------------------------------------
     
    */

    public class Acer{

        
    protected List<String> parts = new ArrayList<String>();
        
        
    //生產CPU
        public void createCPU() {
            
            parts.add(
    "CUP: Intel 酷睿i3 2350M");
        }


        
    //生產內存
        public void createMemory() {

            parts.add(
    "內存: 4GB DDR3 1333MHz");
        }


        
    //生產顯卡
        public void createDisplayCard() {

            parts.add(
    "顯卡: NVIDIA GeForce GT 520M");
        }

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

        }


    }



    Dell.java

    import java.util.ArrayList;
    import java.util.List;
    /**
     * -----------------------------------------
     * @描述  生產戴爾筆記本電腦
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-4 <p>
     * -----------------------------------------
     
    */

    public class Dell{

        
    protected List<String> parts = new ArrayList<String>();

        
    //生產CPU
        public void createCPU() {

            parts.add(
    "CUP: Intel 酷睿i7 3612QM");
        }


        
    //生產內存
        public void createMemory() {

            parts.add(
    "內存: 8GB DDR3 1600MHz");
        }


        
    //生產顯卡
        public void createDisplayCard() {

            parts.add(
    "顯卡: NVIDIA GeForce GT 640M+Intel GMA HD 4000");
        }


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

        }


    }



    Client.java

    /**
     * -----------------------------------------
     * @描述  客戶端測試
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-4 <p>
     * -----------------------------------------
     
    */

    public class Client {

        
    private static Acer acer = new Acer();
        
    private static Dell dell = new Dell();
        
        
    public static void main(String[] args){

            
    /**
             * 宏基
             
    */

            acer.createCPU();
            acer.createMemory();
            acer.createDisplayCard();
            acer.show();
            
            
    /***************************************/
            System.out.println();
            
    /***************************************/
            
           
    /**
             * 戴爾
             
    */

            dell.createCPU();
            dell.createMemory();
            dell.createDisplayCard();
            dell.show();
        }

        
    }



    仔細觀察一下上面的實現,不難發現,不管是生產何種品牌的筆記本,在實現的時候,它們的步驟基本上都是一樣的,都是生產電腦相應的部件并添加都電腦里面,在生產不同品牌電腦

    的時候,都會重復處理這幾個步驟,但是明顯的是,這幾個步驟都是穩定的或者說是一樣的,只是每個步驟的具體實現不一樣或者說是變化的,如果將這些變化的部分抽取出來,也就是

    說如果將處理過程與具體的步驟的實現分離開來的話,這樣就能夠復用這些處理過程,而且這樣一來就能很容易的做到在不同品牌電腦之間切換生產。

    使用 Builder 模式的實現,如圖:


    Product.java

    package pattern.builder;

    import java.util.ArrayList;
    import java.util.List;
    /**
     * -----------------------------------------
     * @描述  抽象產品
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-5 <p>
     * -----------------------------------------
     
    */

    public abstract class Product {

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

        }

    }



    Acer.java

    package pattern.builder;
    /**
     * -----------------------------------------
     * @描述  宏基筆記本
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-5 <p>
     * -----------------------------------------
     
    */

    public class Acer extends Product{

        
    //Do other things here
        
    }



    Dell.java

    package pattern.builder;
    /**
     * -----------------------------------------
     * @描述  戴爾筆記本
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-5 <p>
     * -----------------------------------------
     
    */

    public class Dell extends Product{

        
    //Do other things here
        
    }



    Builder.java

    package pattern.builder;
    /**
     * -----------------------------------------
     * @描述  抽象建造者
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-5 <p>
     * -----------------------------------------
     
    */

    public interface Builder {

        
    //CUP
        public void buildCPU();
        
        
    //內存
        public void buildMemory();
        
        
    //顯卡
        public void buildDisplayCard ();
        
        
    //最終產品
        public Product getFinalResult();
        
    }



    AcerBuilder.java

    package pattern.builder;
    /**
     * -----------------------------------------
     * @描述  宏基筆記本建造者
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-5 <p>
     * -----------------------------------------
     
    */

    public class AcerBuilder implements Builder {

        
    private Product product = new Acer();
        
        @Override
        
    public void buildCPU() {
            
            product.add(
    "CUP: Intel 酷睿i3 2350M");
        }


        @Override
        
    public void buildMemory() {

            product.add(
    "內存: 4GB DDR3 1333MHz");
        }


        @Override
        
    public void buildDisplayCard() {

            product.add(
    "顯卡: NVIDIA GeForce GT 520M");
        }


        @Override
        
    public Product getFinalResult() {
            
            
    return product;
        }


    }



    DellBuilder.java

    package pattern.builder;
    /**
     * -----------------------------------------
     * @描述  戴爾筆記本建造者
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-5 <p>
     * -----------------------------------------
     
    */

    public class DellBuilder implements Builder {

        
    private Product product = new Dell();
        
        @Override
        
    public void buildCPU() {
            
            product.add(
    "CUP: Intel 酷睿i7 3612QM");
        }


        @Override
        
    public void buildMemory() {

            product.add(
    "內存: 8GB DDR3 1600MHz");
        }


        @Override
        
    public void buildDisplayCard() {

            product.add(
    "顯卡: NVIDIA GeForce GT 640M+Intel GMA HD 4000");
        }


        @Override
        
    public Product getFinalResult() {
            
            
    return product;
        }


    }



    Director.java

    package pattern.builder;
    /**
     * -----------------------------------------
     * @描述  產品構建指導者
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-5 <p>
     * -----------------------------------------
     
    */

    public class Director {

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

        
        
    public void construct(){
            
            builder.buildCPU();
            builder.buildMemory();
            builder.buildDisplayCard();
        }

    }



    Client.java

    package pattern.builder;
    /**
     * -----------------------------------------
     * @描述  客戶端測試
     * @作者  fancy
     * @郵箱  fancydeepin@yeah.net
     * @日期  2012-8-5 <p>
     * -----------------------------------------
     
    */

    public class Client {

        
    private static Builder acerBuilder = new AcerBuilder(),
                                                    dellBuilder 
    = new DellBuilder();
        
        
    public static void main(String[] args){
            
            System.out.print(
    "宏基");
            Director director 
    = new Director(acerBuilder);
            director.construct();
            Product product 
    = acerBuilder.getFinalResult();
            product.show();
            
            
    /***************************************/
            System.out.println();
            
    /***************************************/
            
            System.out.print(
    "戴爾");
            director 
    = new Director(dellBuilder);
            director.construct();
            product 
    = dellBuilder.getFinalResult();
            product.show();
        }

        
    }



    后臺輸出:

    宏基產品部件信息:CUP: Intel 酷睿i3 2350M       內存: 4GB DDR3 1333MHz    顯卡: NVIDIA GeForce GT 520M    
    戴爾產品部件信息:CUP: Intel 酷睿i7 3612QM    內存: 8GB DDR3 1600MHz    顯卡: NVIDIA GeForce GT 640M+Intel GMA HD 
    4000


    在這里,Acer 類和 Dell 類是空的,如果是這種情況,那么它們可以省略掉,如果 Product 也不是最終想要的,那么它也可以被省略掉,最終剩下的就只有 Director、Builder、

    和具體的 Bulider 實現類。

    在這里,Acer 類和 Dell 類是有關系的兩個類,它們都是電腦的品牌之一,如果遇到兩個或多個沒有太多關系的類,假設 Acer 類代表電腦,Dell 類代表汽車,很明顯,Acer 類和

    Dell 類就不應該再有共同的父類,也就是這種情況下,Product 這個抽象類不存在了,這時候問題就來了,那么 Builder 接口的規定的 getFinalResult() 方法的返回值怎么確定呢??

    如果它的返回值
    類型是 Acer,那么 DellBuilder 類就會有問題,如果它的返回值類型是 Dell,那么 AcerBuilder 類就會有問題;

    很明顯,這是由于類型不能正確匹配引起的,如果是這種情況,可以將 Product 設計成標識接口(空接口,接口里面沒有規定任何行為方法),再讓這些沒有相互關系的具體產品類

    都去實現這個接口,那么 Builder 接口里面規定的 getFinalResult() 方法的返回值類型依然是 Product 類型,這樣一來問題就解決了。


      
    posted on 2012-08-05 14:03 fancydeepin 閱讀(5849) 評論(4)  編輯  收藏

    評論:
    # re: java 建造者模式(Builder) 2013-02-20 17:35 | rexue
    一看就懂,太好太詳細了  回復  更多評論
      
    # re: java 建造者模式(Builder) 2013-04-18 14:28 | Willy
    謝謝您!  回復  更多評論
      
    # re: java 建造者模式(Builder) 2013-10-11 10:58 | 經典小笑話
    看了幾篇相關的,終于第一篇讓我明白了。因為有一個"不用設計模式的實現",謝謝了,呵~  回復  更多評論
      
    # re: java 建造者模式(Builder) 2016-08-02 11:41 | Nimo
    多謝,講的很清楚  回復  更多評論
      

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 人人狠狠综合久久亚洲高清 | 99久久国产免费中文无字幕| 成人免费看黄20分钟| 亚洲精品成人无码中文毛片不卡| 中文字幕在线日亚洲9| 久久久精品免费国产四虎| 免费国产美女爽到喷出水来视频| 亚洲狠狠狠一区二区三区| 久久精品无码免费不卡| 日韩a在线观看免费观看| 亚洲白嫩在线观看| 中国黄色免费网站| 成年性羞羞视频免费观看无限| 无码人妻精品一二三区免费| 国产真实伦在线视频免费观看| 亚洲第一永久AV网站久久精品男人的天堂AV| 免费国产一级特黄久久| 亚洲一区二区三区在线播放| 国产亚洲人成无码网在线观看| 亚洲日本va在线视频观看| 亚洲国产高清在线| 亚洲人xxx日本人18| 香港经典a毛片免费观看看| 成人电影在线免费观看| 性色av免费观看| 在线观看亚洲成人| 亚洲中文字幕无码爆乳app| 国产精品成人亚洲| 5g影院5g天天爽永久免费影院| 免费看少妇作爱视频| 亚洲AV无码一区二区二三区软件| 国产精品亚洲综合久久 | 亚洲精品免费在线视频| 亚洲最大AV网站在线观看| 曰批全过程免费视频免费看| 免费看美女被靠到爽| 亚洲中文字幕无码久久2017| 亚洲精品国产精品乱码在线观看| 亚洲另类图片另类电影| 两个人的视频www免费| 亚洲片一区二区三区|