Python的組合模式與責任鏈模式編程示例
組合模式
我們把Composite模式看成一個復雜的屬性結(jié)構(gòu),其實基本有三種角色:樹干(定義一些操作樹葉leaf的操作),樹枝(樹干上有很多樹枝)和樹葉(樹干想要具體操作的對象) ,Composite模式幫我們實現(xiàn):即它們在充當對象的時候,還是其他對象的容易,從而提供一致性
python的例子
class Trunk(object): '''樹干''' def __str__(self): pass def subtree(self): pass class Composite(Trunk): def __init__(self, left=None, right=None, length=None): self.left=left self.right=right self.length=length def __str__(self): # 這個結(jié)果是在調(diào)用subtree()的時候返回 if self.length: return "(" + self.left.__str__() + ", " + self.right.__str__() + ")" + ": " + str(self.length) else: return "(" + self.left.__str__() + ", " + self.right.__str__() + ")" # 這里其實就是一個技巧,通過這個函數(shù)返回下一級的對象,也就是它既是對象還可以是對象的容器 def subtree(self): return Composite(self.left, self.right) class Leaf(Trunk): '''葉子類,它沒辦法繼續(xù)延伸了''' def __init__(self, name, length=None): self.name = name self.length=length self.left = None self.right = None def __str__(self): return self.name + ": " + str(self.length) def subtree(self): return Leaf(self.name, self.length) if __name__ == "__main__": # 只有葉子那么就直接返回__str__的拼裝結(jié)果 t1 = Leaf('A', 0.71399) print t1 # 有個2個葉子的組合,返回的是2個葉子的對象的組合 t2 = Composite(Leaf('B', -0.00804), Leaf('C', 0.07470)) print t2 # 這個是嵌套的葉子的組合,樹干上面有樹枝,樹枝上面有葉子 t3 = Composite(Leaf('A', 0.71399), Composite(Leaf('B', -0.00804), Leaf('C', 0.07470), 0.1533), 0.0666) print t3 # 直接通過左右節(jié)點找到對應的葉子對象了 t4 = t3.right.right.subtree() print t4 # t3的左樹其實就是葉子對象了 t5 = t3.left.subtree() print t5
責任鏈模式
比如我們還在讀書的時候,考試的分數(shù)都是幾個檔次,比如90-100分,80-90分,好吧我想做一個根據(jù)分數(shù)打印你的學習成績的反饋, 比如90-100就是A+,80-90就是A,70-80就是B+… 當然你可以用很多種方法實現(xiàn),我這里就來實現(xiàn)一個Chain模式:用一系列的類來響應, 但只有遇到適合處理它的類才會處理,類似與case和switch的作用
python的例子
class BaseHandler: # 它起到了鏈的作用 def successor(self, successor): self.successor = successor class ScoreHandler1(BaseHandler): def handle(self, request): if request > 90 and request <= 100: return "A+" else: # 否則傳給下一個鏈,下同,但是我是要return回結(jié)果的 return self.successor.handle(request) class ScoreHandler2(BaseHandler): def handle(self, request): if request > 80 and request <= 90: return "A" else: return self.successor.handle(request) class ScoreHandler3(BaseHandler): def handle(self, request): if request > 70 and request <= 80: return "B+" else: return "unsatisfactory result" class Client: def __init__(self): h1 = ScoreHandler1() h2 = ScoreHandler2() h3 = ScoreHandler3() # 注意這個順序,h3包含一個類似于default結(jié)果的東西,是要放在最后的,其他的順序是無所謂的,比如h1和h2 h1.successor(h2) h2.successor(h3) requests = {'zhangsan': 78, 'lisi': 98, 'wangwu': 82, 'zhaoliu': 60} for name, score in requests.iteritems(): print '{} is {}'.format(name, h1.handle(score)) if __name__== "__main__": client = Client()
相關文章
Python?matplotlib數(shù)據(jù)可視化圖繪制
這篇文章主要介紹了Python?matplotlib數(shù)據(jù)可視化圖繪制,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-07-07python使用multiprocessing模塊實現(xiàn)帶回調(diào)函數(shù)的異步調(diào)用方法
這篇文章主要介紹了python使用multiprocessing模塊實現(xiàn)帶回調(diào)函數(shù)的異步調(diào)用方法,實例分析了multiprocessing模塊異步調(diào)用的相關使用技巧,需要的朋友可以參考下2015-04-04Pytorch中torch.argmax()函數(shù)使用及說明
這篇文章主要介紹了Pytorch中torch.argmax()函數(shù)使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01python中pycryptodome模塊實現(xiàn)加密算法庫
PyCryptodome提供了許多密碼學算法和協(xié)議的實現(xiàn),包括對稱加密、非對稱加密、消息摘要、密碼哈希、數(shù)字簽名等,本文主要介紹了python中pycryptodome模塊實現(xiàn)加密算法庫,感興趣的可以了解一下2023-11-11python使用pymysql操作MySQL錯誤代碼1054和1064處理方式
這篇文章主要介紹了python使用pymysql操作MySQL錯誤代碼1054和1064處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06利用Python3分析sitemap.xml并抓取導出全站鏈接詳解
因為最近更換了網(wǎng)址,所以需要在百度站長平臺提交網(wǎng)址,不管是主動推送還是手動提交,前提都是要整理網(wǎng)站的鏈接,手動添加太麻煩,于是就想寫個腳本直接抓取全站鏈接并導出,本文詳細介紹的是實現(xiàn)的方法及過程,需要的朋友們一起來看看吧。2017-07-07