熱線電話:13121318867

登錄
首頁精彩閱讀Python的組合模式與責任鏈模式編程示例
Python的組合模式與責任鏈模式編程示例
2018-04-22
收藏

Python的組合模式與責任鏈模式編程示例

這篇文章主要介紹了Python的組合模式與責任鏈模式編程示例,組合模式與責任鏈模式都屬于Python的設計模式,需要的朋友可以參考下

組合模式

我們把Composite模式看成一個復雜的屬性結構,其實基本有三種角色:樹干(定義一些操作樹葉leaf的操作),樹枝(樹干上有很多樹枝)和樹葉(樹干想要具體操作的對象) ,Composite模式幫我們實現:即它們在充當對象的時候,還是其他對象的容易,從而提供一致性
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):
    # 這個結果是在調用subtree()的時候返回
    if self.length:
      return "(" + self.left.__str__() + ", " + self.right.__str__() + ")" + ": " + str(self.length)
    else:
      return "(" + self.left.__str__() + ", " + self.right.__str__() + ")"
 
    # 這里其實就是一個技巧,通過這個函數返回下一級的對象,也就是它既是對象還可以是對象的容器
    def subtree(self):        
      return Composite(self.left, self.right)
 
class Leaf(Trunk):
  '''葉子類,它沒辦法繼續延伸了'''
  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__的拼裝結果
  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
  # 直接通過左右節點找到對應的葉子對象了
  t4 = t3.right.right.subtree()
  print t4
  # t3的左樹其實就是葉子對象了
  t5 = t3.left.subtree()
  print t5
責任鏈模式
比如我們還在讀書的時候,考試的分數都是幾個檔次,比如90-100分,80-90分,好吧我想做一個根據分數打印你的學習成績的反饋, 比如90-100就是A+,80-90就是A,70-80就是B+… 當然你可以用很多種方法實現,我這里就來實現一個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回結果的
      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結果的東西,是要放在最后的,其他的順序是無所謂的,比如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()

數據分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數據分析師資訊
更多

OK
客服在線
立即咨詢
日韩人妻系列无码专区视频,先锋高清无码,无码免费视欧非,国精产品一区一区三区无码
客服在線
立即咨詢