建造者模式,将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。如果你需要将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。下面看一下建造者的例子
1、需要构建的产品类,产品由多个部件组成
public class Product { private List<String> parts = new ArrayList<String>(); public void add(String part){ parts.add(part); } public void show(){ for(String part:parts){ System.out.println(part); } } }2、抽象建造者类确定产品由两个部件组成,并声明一个得到产品的建造后结果的方法。
public abstract class Builder { public abstract void buildPartA(); public abstract void buildPartB(); public abstract Product getResult(); }3、具体建造者类,我们列举了两个可以是多个。
public class ConcreteBuilder1 extends Builder{ private Product product = new Product(); @Override public void buildPartA() { product.add("部件A"); } @Override public void buildPartB() { product.add("部件B"); } @Override public Product getResult() { return product; } }
public class ConcreteBuilder2 extends Builder{ private Product product = new Product(); @Override public void buildPartA() { product.add("部件X"); } @Override public void buildPartB() { product.add("部件Y"); } @Override public Product getResult() { return product; } }
public class Director { public void construct(Builder builder){ builder.buildPartA(); builder.buildPartB(); } }5、测试
public class Test { public static void main(String[] args) { Director director = new Director(); Builder b1 = new ConcreteBuilder1(); Builder b2 = new ConcreteBuilder2(); director.construct(b1); Product p1 = b1.getResult(); p1.show(); director.construct(b2); Product p2 = b2.getResult(); p2.show(); } }