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

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.
主站蜘蛛池模板: 镇坪县| 诏安县| 饶河县| 德州市| 平和县| 乌苏市| 贞丰县| 隆子县| 射洪县| 新邵县| 汝南县| 青龙| 潞西市| 开封市| 鹿泉市| 莱西市| 新余市| 榆社县| 嘉祥县| 海南省| 平凉市| 镇康县| 厦门市| 双城市| 佳木斯市| 永年县| 博野县| 罗甸县| 莒南县| 新和县| 克山县| 昔阳县| 察隅县| 申扎县| 井陉县| 庄河市| 高青县| 四会市| 平昌县| 大化| 西林县|