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