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.