"""
*What is this pattern about?
It decouples the creation of a complex object and its representation,
so that the same process can be reused to build objects from the same
family.
This is useful when you must separate the specification of an object
from its actual representation (generally for abstraction).
*What does this example do?
The first example achieves this by using an abstract base
class for a building, where the initializer (__init__ method) specifies the
steps needed, and the concrete subclasses implement these steps.
In other programming languages, a more complex arrangement is sometimes
necessary. In particular, you cannot have polymorphic behaviour in a constructor in C++ -
see https://stackoverflow.com/questions/1453131/how-can-i-get-polymorphic-behavior-in-a-c-constructor
- which means this Python technique will not work. The polymorphism
required has to be provided by an external, already constructed
instance of a different class.
In general, in Python this won't be necessary, but a second example showing
this kind of arrangement is also included.
*Where is the pattern used practically?
*References:
https://sourcemaking.com/design_patterns/builder
*TL;DR
Decouples the creation of a complex object and its representation.
"""# Abstract BuildingclassBuilding:def__init__(self):
self.build_floor()
self.build_size()defbuild_floor(self):raise NotImplementedError
defbuild_size(self):raise NotImplementedError
def__repr__(self):return'Floor: {0.floor} | Size: {0.size}'.format(self)# Concrete BuildingsclassHouse(Building):defbuild_floor(self):
self.floor ='One'defbuild_size(self):
self.size ='Big'classFlat(Building):defbuild_floor(self):
self.floor ='More than One'defbuild_size(self):
self.size ='Small'# In some very complex cases, it might be desirable to pull out the building# logic into another function (or a method on another class), rather than being# in the base class '__init__'. (This leaves you in the strange situation where# a concrete class does not have a useful constructor)classComplexBuilding:def__repr__(self):return'Floor: {0.floor} | Size: {0.size}'.format(self)classComplexHouse(ComplexBuilding):defbuild_floor(self):
self.floor ='One'defbuild_size(self):
self.size ='Big and fancy'defconstruct_building(cls):
building = cls()
building.build_floor()
building.build_size()return building
defmain():"""
>>> house = House()
>>> house
Floor: One | Size: Big
>>> flat = Flat()
>>> flat
Floor: More than One | Size: Small
# Using an external constructor function:
>>> complex_house = construct_building(ComplexHouse)
>>> complex_house
Floor: One | Size: Big and fancy
"""if __name__ =="__main__":import doctest
doctest.testmod()
builder模式"""*What is this pattern about?It decouples the creation of a complex object and its representation,so that the same process can be reused to build objects from the samefamily.This is u...