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

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.
主站蜘蛛池模板: 昆山市| 贵溪市| 行唐县| 高唐县| 泰来县| 陈巴尔虎旗| 布拖县| 息烽县| 宁海县| 环江| 通江县| 大连市| 松潘县| 修文县| 兴海县| 定兴县| 察隅县| 南宁市| 酉阳| 鹤峰县| 和林格尔县| 道真| 嘉兴市| 太康县| 曲沃县| 内黄县| 含山县| 德格县| 平原县| 台东市| 上林县| 巴楚县| 汉川市| 永登县| 宁都县| 云梦县| 武乡县| 闽清县| 芒康县| 平定县| 邯郸县|