乐趣区

Python3-实现建造者模式

建造者模式

建造者模式用于创建复杂的对象。使用建造者模式可以使复杂的过程层次明了、清晰,把对象的创建以及使用进行了解耦。实际上从代码的角度上看,是进行了多次封装,使代码结构更为规范合理,层次结构更加鲜明。

在一个复杂的对象中,需要编写大量的代码去实现这一个类,并且在进行初始化时,也有可能会有大量的参数去进行初始化。

建造者模式把实现一个类给拆分成多个创建步骤,这些步骤在大多数相关资料中,一般以拟人化的形式进行表达;例如建造者、指挥者以及导演者,但是这些名词的拟人化并不能完全的让读者能够 get 到完整的含义。以下将详细讲解这几个角色所需要做的事务。

此篇是一个水文,就用建房子来作为一个简单示例讲解。

首先我们创建一个房子的基类来模拟房子:

class House:# 房子基类
    def __init__(self):
        self.size=0
        self.floor=0
        self.garage=0
        self.courtyard=0
    def __str__(self):
        houseInfo='我的房子有'+str(self.size)+'平米,'+str(self.floor)+'层楼,'+str(self.garage)+'个车库'+str(self.courtyard)+'个院子'
        return houseInfo

其中使用 size、floor、garage、courtyard 用以记录房子的信息,以便之后工人在建造房子的时候作为记录。

接下来我们建造一个工人类,用来具体去建造我们的房子:

class HouseBuilder:# 建造者类工人
    def __init__(self):
        self.house=House()
    def buildGarage(self,amount):
        self.house.garage=amount
        print(self.house)
    def buildFloor(self,amount):
        self.house.floor=amount
        print(self.house)
    def buildSize(self,amount):
        self.house.size=amount
        print(self.house)
    def buildCourtyard(self,amount):
        self.house.courtyard=amount
        print(self.house)

定义了建造 size 尺寸占地面积、garage 车库数量、floor 房屋楼层以及 courtyard 庭院数量,并且在这些方法中都传入了一个参数用作设置这些信息。

有了工人后,再来一个包工头,包工头更好的去统筹建造适宜,同时也是跟用户的对接人。

class Foreman:# 领班
    def __init__(self):
        self.builder=HouseBuilder()
    def build(self,size,floor,garage,courtyard):# 建造步骤
        self.builder.buildSize(size)
        self.builder.buildFloor(floor)
        self.builder.buildGarage(garage)
        self.builder.buildCourtyard(courtyard)

在包工头的初始化函数中,新建一个工人类,也就是房子的建造者,之后定义了一个 build 方法用于建造,建造时一般为首先确定面积大小,随后建造房屋(楼层),再建造车库以及庭院。

这个时候一个简单的建造者模式就完成了,为了更好的进行说明,我新建了一个 User 类,这个 User 类并不需要了解其中具体完成,只需要对接包工头,这个时候告诉包工头我的占地大小,房屋大小以及一些参数后,包工头告诉给他的小弟们,这个时候就可以开始建造了,用户并不需要了解其建造过程。代码如下:

class User():# 用户
    def __init__(self,size,floor,garage,courtyard):
        self.frm=Foreman()
        self.frm.build(size,floor,garage,courtyard)

完整代码如下:

class House:# 房子基类
    def __init__(self):
        self.size=0
        self.floor=0
        self.garage=0
        self.courtyard=0
    def __str__(self):
        houseInfo='我的房子有'+str(self.size)+'平米,'+str(self.floor)+'层楼,'+str(self.garage)+'个车库'+str(self.courtyard)+'个院子'
        return houseInfo
        
class HouseBuilder:# 建造者类工人
    def __init__(self):
        self.house=House()
    def buildGarage(self,amount):
        self.house.garage=amount
        print(self.house)
    def buildFloor(self,amount):
        self.house.floor=amount
        print(self.house)
    def buildSize(self,amount):
        self.house.size=amount
        print(self.house)
    def buildCourtyard(self,amount):
        self.house.courtyard=amount
        print(self.house)

class Foreman:# 领班
    def __init__(self):
        self.builder=HouseBuilder()
    def build(self,size,floor,garage,courtyard):# 建造步骤
        self.builder.buildSize(size)
        self.builder.buildFloor(floor)
        self.builder.buildGarage(garage)
        self.builder.buildCourtyard(courtyard)

class User():# 用户
    def __init__(self,size,floor,garage,courtyard):
        self.frm=Foreman()
        self.frm.build(size,floor,garage,courtyard)

        
xiaoming=User(500,3,2,1)

运行结果如下:

设计模式有一定的局限性,具体使用场景得具体分析。

退出移动版