[python|高級篇|筆記|設計模式|策略模式]
引子
接著開始吧,還是讀了HF之后的學習記錄。
繼承并不是適當的解決方式,因為對象的行為在子類里面不斷變化,并且讓所有子類都有這些行為是不恰當的。
設計原則
找出可能需要變化的部分,把他們獨立出來,不要和那些不需要變化的代碼混在一起
正文
如果每次新的需求一來,都會使某方面的代碼變化,那么就可以確定,這部分的代碼需要抽離出來,和其他穩定的代碼有所區分,把會變化的部分取出來并封裝起來,以便以后可以輕易地改動或擴充此部分,而不影響不需要變化的其他部分。
找個例子來說明這個事,設計一個游戲,游戲里面有各種各樣的武器,各種各樣的職業,各種各樣的技能,這里需要創建一個拿著劍具有玉女心經劍法技能的國王職業的人物,該怎么去實現呢?
先取出要變化的部分,武器,技能,人物可能都會發生變化,我可能增加一個武器,修煉一項新的技能,創建一個新的職業,這些變化的部分取出來,單獨實現。
接著創建一個客戶類,由用戶自行制定需要創建出什么樣的人物
代碼
分別定義武器,職業,技能的實現
武器
class SwordBehavior(object):
def __init__(self):
self.behaviorCode = "SWORD"
def __call__(self):
return "use the sword"
class KnifeBehavior(object):
def __init__(self):
self.behaviorCode = "KNIFE"
def __call__(self):
return "use the knife"
class BowAndArrowBehavior(object):
def __init__(self):
self.behaviorCode = "BOWANDARROW"
def __call__(self):
return "use the bow and arrow"
class AxeBehavior(object):
def __init__(self):
self.behaviorCode = "AXE"
def __call__(self):
return "use the axe"
職業
class KingFigure(object):
def __init__(self):
self.figureCode = "KING"
def __call__(self):
return "I am a king"
class QueenFigure(object):
def __init__(self):
self.figureCode = "QUEEN"
def __call__(self):
return "I am a queen"
class TrollFigure(object):
def __init__(self):
self.figureCode = "TROLL"
def __call__(self):
return "I am a troll"
class KnightFigure(object):
def __init__(self):
self.figureCode = "KNIGHT"
def __call__(self):
return "I am a knight"
技能
class attack1Method(object):
def __init__(self):
self.attackCode = "ATTACK1"
def __call__(self):
return "with attack1"
class attack2Method(object):
def __init__(self):
self.attackCode = "ATTACK2"
def __call__(self):
return "with attack2"
class attack3Method(object):
def __init__(self):
self.attackCode = "ATTACK3"
def __call__(self):
return "with attack3"
創建一個類來設定每個人物
class CharacterCreator(object):
def __init__(self):
self.__weaponImpls = [SwordBehavior(),
KnifeBehavior(),
BowAndArrowBehavior(),
AxeBehavior()]
self.__figureImpls = [KingFigure(),
QueenFigure(),
TrollFigure(),
KnightFigure()]
self.__attackImpls = [attack1Method(),
attack2Method(),
attack3Method]
def __call__(self, weapon, character, attack):
for wimpl in self.__weaponImpls:
if wimpl.behaviorCode == weapon:
for fimpl in self.__figureImpls:
if fimpl.figureCode == character:
for aimpl in self.__attackImpls:
if aimpl.attackCode == attack:
return fimpl() + " " +wimpl() + " " + aimpl()
之后,搞點數據測試一下
def main():
chracterCreator = CharacterCreator()
king = chracterCreator("SWORD", "KING", "ATTACK1")
queen = chracterCreator("KNIFE", "QUEEN", "ATTACK2")
print(king)
print(queen)
if __name__ == '__main__':
main()
輸出的結果
I am a king use the sword with attack1
I am a queen use the knife with attack2
尾聲
這就是策略模式,也不知道對不對。