美文网首页
建造者模式

建造者模式

作者: 杨殿生 | 来源:发表于2019-01-15 14:46 被阅读0次

    1,建造者模式是一个创建对象的模式
    2,与工厂模式很像,建造者模式主要思考的方向是零件的顺序不同创建对象不同,工厂方法不会关注创建零件时的顺序
    3,建造者模式经常和模板方法一起使用

    看一下类图


    建造者模式类图

    1,需要有产品的抽象类定义产品生成规则
    2,产品实现类实现产品具体行为(这里就使用了模板方法模式)
    3,建造者抽象类构造产品规则
    4,建造者实现类构造具体的产品
    5,执行类隔离高层组件按顺序构造各种产品

    下面我们使用建造者模式来构造汽车
    需求:我们需要建造汽车类,可以构造不同,汽车有如下功能(启动,停止,喇叭执行声音,引擎执行声音)。汽车运行时会执行以上不同方法,并且方法顺序不固定

    我们来一步步实现这个需求
    1,构造车的抽象类
    使用一个集合存储基本执行方法的顺序

    public abstract class CarModel {
        //这个参数是各个基本方法执行的顺序
        private ArrayList<String> sequence = new ArrayList<>();
        //模型开始跑了
        abstract void start();
        //停止
        abstract void stop();
        //喇叭声音
        abstract void alarm();
        //引擎隆隆响
        abstract void engineBoom();
    
        public final void run(){
            //循环,谁在前,谁先执行
            for (String s:sequence){
                if (s.equals("start")){
                    this.start();
                } else if (s.equals("stop")){
                    this.stop();
                }if (s.equals("alarm")){
                    this.alarm();
                }if (s.equals("engineBoom")){
                    this.engineBoom();
                }
            }
        }
    
        //把值传递到类内
        public void setSequence(ArrayList sequence){
            this.sequence = sequence;
        }
    }
    

    2,汽车的具体实现类,比如我们要成产两种车,奔驰和宝马

    public class BMWModel extends CarModel{
        @Override
        void start() {
            System.out.println("宝马start");
        }
    
        @Override
        void stop() {
            System.out.println("宝马stop");
        }
    
        @Override
        void alarm() {
            System.out.println("宝马alarm");
        }
    
        @Override
        void engineBoom() {
            System.out.println("宝马engineBoom");
        }
    }
    
    
    public class BenzModel extends CarModel{
        @Override
        void start() {
            System.out.println("奔驰start");
        }
    
        @Override
        void stop() {
            System.out.println("奔驰stop");
        }
    
        @Override
        void alarm() {
            System.out.println("奔驰alarm");
        }
    
        @Override
        void engineBoom() {
            System.out.println("奔驰engineBoom");
        }
    }
    

    3,建造者的抽象类,建造者的抽象规则

    public abstract class CarBuilder {
        //确定运行的顺序
        public abstract void setSequence(ArrayList<String> sequence);
        public abstract CarModel getCarModel();
    }
    

    4,建造者实现类,有几个产品就实现几个建造者类,我们这里有两个产品,所以有两个

    public class BMWBuilder extends CarBuilder{
    
        private BMWModel bmwModel = new BMWModel();
        @Override
        public void setSequence(ArrayList<String> sequence) {
            bmwModel.setSequence(sequence);
        }
    
        @Override
        public CarModel getCarModel() {
            return bmwModel;
        }
    }
    
    public class BenzBuilder extends CarBuilder{
    
        private BenzModel benz = new BenzModel();
    
        @Override
        public void setSequence(ArrayList<String> sequence) {
            this.benz.setSequence(sequence);
        }
    
        @Override
        public CarModel getCarModel() {
            return benz;
        }
    }
    

    5,执行类,用于隔离上层组件和组装对象的管理类
    执行创建产品前都需要清空基本方法执行顺序

    public class Director {
        private ArrayList<String> sequence = new ArrayList<>();
        private BenzBuilder benzBuilder = new BenzBuilder();
        private BMWBuilder bmwBuilder = new BMWBuilder();
    
        public BenzModel getABenzBuilder() {
            this.sequence.clear();
            this.sequence.add("start");
            this.sequence.add("stop");
            this.benzBuilder.setSequence(sequence);
            return (BenzModel) benzBuilder.getCarModel();
        }
    
        public BenzModel getBBenzBuilder() {
            this.sequence.clear();
            this.sequence.add("start");
            this.sequence.add("alarm");
            this.benzBuilder.setSequence(sequence);
            return (BenzModel) benzBuilder.getCarModel();
        }
    
        public BMWModel getABMWBuilder() {
            this.sequence.clear();
            this.sequence.add("engineBoom");
            this.sequence.add("stop");
            this.bmwBuilder.setSequence(sequence);
            return (BMWModel) bmwBuilder.getCarModel();
        }
    
        public BMWModel getBBMWBuilder() {
            this.sequence.clear();
            this.sequence.add("alarm");
            this.sequence.add("stop");
            this.bmwBuilder.setSequence(sequence);
            return (BMWModel) bmwBuilder.getCarModel();
        }
    }
    

    6,调用

    public class Main {
        public static void main(String[] args){
            BenzModel benzModel = new Director().getBBenzBuilder();
            benzModel.run();
        }
    }
    

    我们看到调用非常简单,并且如果我们需要扩展非常方便,比如加一个保时捷,只需要在增加一个保时捷的实现类,和一个保时捷的建造者,在管理类中增加生产保时捷的对象方法就可以了

    相关文章

      网友评论

          本文标题:建造者模式

          本文链接:https://www.haomeiwen.com/subject/pzhydqtx.html