在用户不知道对象建造的过程和细节的情况下,直接创建复杂对象。将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示(根据不同的参数以及顺序)
    建造者模式定制、工厂模式流水线

    与工厂模式的区别
    (1)建造者模式更加注重方法的调用顺序,工厂模式注重创建对象。
    (2)创建对象的力度不同,建造者模式创建复杂的对象,由各种复杂的部件组成,工厂模式创建出来的对象都一样。
    (3)关注重点不一样,工厂模式只需要把对象创建出来就可以了,而建造者模式不仅要创建出对象,还要知道对象由哪些部件组成。
    (4)建造者模式根据建造过程中的顺序不一样,最终的对象部件组成也不一样。

    image.png
    Director可以被简化

    1. public abstract class IBuilder {
    2. public abstract Product build();
    3. static class ABuilder extends IBuilder{
    4. Product product = new Product();
    5. public Product addCode(String code){
    6. product.setCode(code);
    7. return product;
    8. }
    9. public Product addDesc(String desc){
    10. product.setDesc(desc);
    11. return product;
    12. }
    13. @Override
    14. public Product build() {
    15. return product;
    16. }
    17. };
    18. }

    框架用例:

    • Spring的BeanDefinitionBuilder
    • Mybatis的SqlSessionFactoryBuilder和CacheBuilder
    • StringBuilder

    优点
    (1)封装性好,构建和表示分离。 客户端不必知道产品内部组成的细节
    (2)扩展性好,建造类之间独立,在一定程度上解耦。
    (3)便于控制细节,建造者可以对创建过程逐步细化,而不对其他模块产生任何影响。

    缺点
    (1)需要多创建一个IBuilder对象。
    (2)如果产品内部发生变化,则建造者也要同步修改,后期维护成本较大。

    使用场景:
    ● 相同的方法,不同的执行顺序,产生不同的事件结果时,可以采用建造者模式。
    ● 多个部件或零件,都可以装配到一个对象中,但是产生的运行结果又不相同时,则可 以使用该模式。
    ● 产品类非常复杂,或者产品类中的调用顺序不同产生了不同的效能,这个时候使用建 造者模式非常合适。