官术网_书友最值得收藏!

Builder pattern

The builder pattern serves the same purpose as the other creational patterns, but it does so in a different way and for different reasons. When developing complex applications, the code tends to become more complex. Classes tend to encapsulate more functionality and, at the same time, class structures become more complex. As the functionality grows, more scenarios need to be covered and, for these, different representations of classes are required.

When we have a complex class that we need to instantiate to different objects with different structures or different internal states, we can use separate classes to encapsulate the instantiation logic. These classes are called builders. Each time we need objects from the same class with a different structure, we can create another builder to create such instances.

The same concept can be used not only for classes for which we need different representations but also for complex objects composed of other objects.

Creating builder classes to encapsulate the logic to instantiate complex objects is consistent with the single responsibility principle and with the open/closed principle. The logic to instantiate a complex object is moved to a separate Builder class. When we need objects with different structures, we can add new builder classes, so the code is closed for modification and open for extension, as shown in the diagram:

The following classes are involved in the builder pattern:

  • Product: The class whose objects we have to build. It is a complex or a composite object of which we need different representations.
  • Builder: The abstract class or interface which declares the parts from which the product is built. Its role is to expose only the functionality required to build the Product, hiding the rest of the Product functionality; it decouples the Product from the higher-level class that builds it.
  • ConcreteBuilder: A concrete builder that implements the methods declared in the Builder interface. In addition to the methods declared in the Builder abstract class, it has a getResult method that returns the built product.
  • Director: A class that directs how the object is built. In some variants of the builder pattern this class is removed, its role being taken by either the client or the builder.
主站蜘蛛池模板: 确山县| 芦山县| 山西省| 深圳市| 绥棱县| 泊头市| 遂宁市| 汝州市| 河北区| 襄城县| 阜城县| 开江县| 闽清县| 奉新县| 玉林市| 清河县| 颍上县| 临夏市| 突泉县| 临清市| 贵定县| 二连浩特市| 洛扎县| 灵石县| 定襄县| 武强县| 云龙县| 镇安县| 阿瓦提县| 石阡县| 塔城市| 合山市| 宁乡县| 岳池县| 高要市| 腾冲县| 武隆县| 察雅县| 上林县| 鄄城县| 从江县|