定义
建造者模式:将一个复杂的对象的构建与它的表示分离,使得同样的构建过程可以构建不同的表示
Builder Pattern: Separate the construction of a complex object from its representation so that the same construction process can create different representations
优点
- 封装性,可以使客户端不必知道产品内部组成细节
- 建造者独立,容易扩展
- 便于控制细节风险
使用场景
- 相同的方法,不同的执行顺序,产生不同的时间结果时
- 多个部件或零件,都可以装配到一个对象中,但是产生的运行结果又不相同时
- 产生类非常复杂,或者产品类中的调用顺序不同产生了不同的效能
实现方法
Product产品类:通常实现了模板方法模式
Builder抽象建造者:规范产品的组建,一般由子类实现
ConcreteBuilder具体建造者:实现抽象类定义的所有方法,并返回一个建造好的对象
Director导演类:负责安排已有模块的顺序,然后告诉Builder开始建造
具体实现
产品抽象类
public abstract class CarModel { private ArrayList<String> sequence = new ArrayList<String>(); protected abstract void start(); protected abstract void stop(); protected abstract void alarm(); protected abstract void engineBoom(); final public void run() { for (int i = 0; i < sequence.size(); i++) { String actionName = this.sequence.get(i); if (actionName.equalsIgnoreCase("start")) { this.start(); } else if (actionName.equalsIgnoreCase("stop")) { this.stop(); } else if (actionName.equalsIgnoreCase("alarm")) { this.alarm(); } else if (actionName.equalsIgnoreCase("engine boom")) { this.engineBoom(); } } } final public void setSequence(ArrayList<String> sequence) { this.sequence = sequence; } }
产品实现类A
public class BenzModel extends CarModel { @Override protected void start() { System.out.println("Benz Start!"); } @Override protected void stop() { System.out.println("Benz Stop!"); } @Override protected void alarm() { System.out.println("Benz Alarm!"); } @Override protected void engineBoom() { System.out.println("Benz Engine Boom!"); } }
产品实现类B
public class BMWModel extends CarModel { @Override protected void start() { System.out.println("BMW Start!"); } @Override protected void stop() { System.out.println("BMW Stop!"); } @Override protected void alarm() { System.out.println("BMW Alarm!"); } @Override protected void engineBoom() { System.out.println("BMW Engine Boom!"); } }
抽象建造者
public abstract class CarBuilder { public abstract void setSequence(ArrayList<String> sequence); public abstract CarModel getCarModel(); }
具体建造者A
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; } }
具体建造者B
public class BMWBuilder extends CarBuilder { private BMWModel bmw = new BMWModel(); @Override public void setSequence(ArrayList<String> sequence) { this.bmw.setSequence(sequence); } @Override public CarModel getCarModel() { return bmw; } }
导演类
public class Director { private ArrayList<String> sequence = new ArrayList<String>(); private BenzBuilder benzBuilder = new BenzBuilder(); private BMWBuilder bmwBuilder = new BMWBuilder(); public BenzModel getABenzModel() { this.sequence.clear(); this.sequence.add("start"); this.sequence.add("stop"); this.benzBuilder.setSequence(sequence); return (BenzModel) this.benzBuilder.getCarModel(); } public BenzModel getBBenzModel() { this.sequence.clear(); this.sequence.add("engine boom"); this.sequence.add("start"); this.sequence.add("stop"); this.benzBuilder.setSequence(sequence); return (BenzModel) this.benzBuilder.getCarModel(); } public BMWModel getABMWModel() { this.sequence.clear(); this.sequence.add("start"); this.sequence.add("stop"); this.bmwBuilder.setSequence(sequence); return (BMWModel) this.bmwBuilder.getCarModel(); } public BMWModel getBBMWModel() { this.sequence.clear(); this.sequence.add("engine boom"); this.sequence.add("start"); this.sequence.add("stop"); this.bmwBuilder.setSequence(sequence); return (BMWModel) this.bmwBuilder.getCarModel(); } }
场景类
public class Client { public static void main(String[] args) { Director director = new Director(); for (int i = 0; i < 2; i++) { director.getABenzModel().run(); } for (int i = 0; i < 3; i++) { director.getBBenzModel().run(); } for (int i = 0; i < 2; i++) { director.getABMWModel().run(); } for (int i = 0; i < 3; i++) { director.getBBMWModel().run(); } } }
PS:基本理解这种写法的思想和意义,但不深刻
参考内容:
《设计模式之禅》秦小波
相关推荐
这个http://blog.csdn.net/dawanganban/article/details/9990405博客中java设计模式的源代码。下载前请先看《设计模式——建造者模式》一文。
设计模式之建造者模式代码示例,
Java设计模式-建造者模式详解
整个设计模式领域还很新,本书的四位作者也许已占据了这个领域造诣最深的专家中的半数,因而他们定义模式的方法可以作为后来者的榜样。如果要知道怎样恰当定义和描述设计模式,我们应该可以从他们那儿获得启发”--steve...
java23中常用设计模式之建造者模式,详细源码分析请见: http://blog.csdn.net/github_22022001/article/details/42120867
建造者模式: 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表现。这就是建造者模式。 建造者模式可以把一个产品的内部表象与产品的生成过程分隔开来,从而可以使一个建造过程就可以生成...
用幽默的方式写下这些设计模式,代码里面有相应注解,不会很难理解,每个包里面有1-2个代码事例,还有一点小说明,还有本人qq,现在只有5种,其他的设计模式期待下一个版本吧!
C#设计模式之建造者模式应用实例
用一个建造房屋的生动实例讲述了设计模式中常用的建造者模式的真谛,跟大家一起交流。附有相应类图
java设计模式【之】建造者模式【源码】【场景:车辆组装】 将复杂的对象构建,与对象的使用进行分离 用户只需要通过简单流程即可创建出对象 方法调用顺序,步骤的不同实现 优点:封装性号,创建和使用分离,扩展性...
设计模式例子,观察者模式,建造者模式,一些实践的例子,通俗易懂.
设计模式-建造者模式,该模式涉及产品,构造者,指挥者、调用者等几个角色,职责明确,在实际项目中使用得比较多。
设计模式-建造者模式(讲解及其实现代码)
Java描述设计模式:建造者模式 07 Java描述设计模式:适配器模式 08 Java描述设计模式:桥接模式 09 Java描述设计模式:装饰模式 10 Java描述设计模式:组合模式 11 Java描述设计模式:观察者模式 12 Java描述设计...
设计模式实验报告-建造者,有代码实例和运行结果
NULL 博文链接:https://wy649898543.iteye.com/blog/1431751
根据官方的设计模式,自己写的源码,有什么不对的地方还望交流
创建型设计模式:简单工厂模式,工厂方法模式,抽象工厂模式,建造者模式,原型模式,单例模式; 结构型设计模式:适配器模式,桥接模式,组合模式,装饰模式,外观模式,轻量级模式,代理模式; 行为性设计模式:...