日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

sjms-4 行为型模式

發布時間:2024/9/3 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 sjms-4 行为型模式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

行為型模式

責任鏈模式


內容:使多個對象都有機會處理請求,從而避免請求的發送者和接收者之間的耦合關系。
將這些對象連成一條鏈,并沿著這條鏈傳遞該請求,直到有一個對象處理它為止。
角色:
抽象處理者(Handler)
具體處理者(ConcreteHandler)
客戶端(Client)

from abc import ABCMeta, abstractmethodclass Handler(metaclass=ABCMeta):@abstractmethoddef handle_leave(self, day):passclass GeneralManager(Handler):def handle_leave(self, day):if day <= 10:print("總經理準假%d天" % day)else:print("你還是辭職吧")class DepartmentManager(Handler):def __init__(self):self.next = GeneralManager()def handle_leave(self, day):if day <= 5:print("部門經理準假%s天" % day)else:print("部門經理職權不足")self.next.handle_leave(day)class ProjectDirector(Handler):def __init__(self):self.next = DepartmentManager()def handle_leave(self, day):if day <= 3:print("項目主管準假%d天" % day)else:print("項目主管職權不足")self.next.handle_leave(day)day = 12 h = ProjectDirector() h.handle_leave(day)


適用場景:
有多個對象可以處理一個請求,哪個對象處理由運行時決定
在不明確接收者的情況下,向多個對象中的一個提交一個請求
優點:
降低耦合度:一個對象無需知道是其他哪一個對象處理其請求

觀察者模式

內容:定義對象間的一種一對多的依賴關系,當一個對象的狀態發生改變時,?所有依賴于它的對象都得到
通知并被自動更新。觀察者模式又稱“發布-訂閱”模式
角色:
抽象主題(Subject)
具體主題(ConcreteSubject)——發布者
抽象觀察者(Observer)
具體觀察者(ConcreteObserver)——訂閱者

?

from abc import ABCMeta, abstractmethodclass Observer(metaclass=ABCMeta): # 抽象訂閱者@abstractmethoddef update(self, notice): # notice 是一個Notice類的對象,以便過去Notice更新的消息passclass Notice: # 抽象發布者def __init__(self):self.observers = []def attach(self, obs):self.observers.append(obs) # 添加訂閱def detach(self, obs):self.observers.remove(obs) # 取消訂閱def notify(self): # 向訂閱者推送消息for obs in self.observers:obs.update(self) # 對訂閱者的消息進行更新class StaffNotice(Notice): # 具體發布者def __init__(self, company_info=None):super().__init__()self.__company_info = company_info@propertydef company_info(self):return self.__company_info@company_info.setterdef company_info(self, info):self.__company_info = infoself.notify() # 一有改變就向訂閱者發送消息,并調用訂閱者的消息更新方法class Staff(Observer):def __init__(self):self.company_info = Nonedef update(self, notice): # 獲取消息更新的方法self.company_info = notice.company_info# Clientnotice = StaffNotice("初始公司信息")s1 = Staff() s2 = Staff()notice.attach(s1) notice.attach(s2)notice.company_info = "公司今年業績非常好,給大家發獎金!!!" print(s1.company_info) print(s2.company_info) notice.detach(s2) notice.company_info = "公司明天放假!!!" print(s1.company_info) print(s2.company_info)""" 公司今年業績非常好,給大家發獎金!!! 公司今年業績非常好,給大家發獎金!!! 公司明天放假!!! 公司今年業績非常好,給大家發獎金!!!"""


適用場景:
當一個抽象模型有兩方面,其中一個方面依賴于另一個方面。將這兩者封裝在獨立對象中以使它們可以各自獨立地改變和
復用。
當對一個對象的改變需要同時改變其它對象,而不知道具體有多少對象有待改變。
當一個對象必須通知其它對象,而它又不能假定其它對象是誰。換言之,你不希望這些對象是緊密耦合的。
優點:
目標和觀察者之間的抽象耦合最小
支持廣播通信

策略模式

內容:定義一系列的算法,把它們一個個封裝起來,并且使它們可相互替換。本模式使
得算法可獨立于使用它的客戶而變化。
角色:
抽象策略(Strategy)
具體策略(ConcreteStrategy)
上下文(Context)

from abc import ABCMeta, abstractmethodclass Strategy(metaclass=ABCMeta):@abstractmethoddef execute(self, data):passclass FastStrategy(Strategy):def execute(self, data):print("用較快的策略處理%s" % data)class SlowStrategy(Strategy):def execute(self, data):print("用較慢的策略處理%s" % data)class Context:def __init__(self, strategy, data): # 將對數據處理的方法封裝起來self.data = dataself.strategy = strategydef set_strategy(self, strategy): #設置策略self.strategy = strategydef do_strategy(self): # 執行策略的方法self.strategy.execute(self.data)data = "[...]" s1 = FastStrategy() s2 = SlowStrategy() context = Context(s1, data) context.do_strategy() context.set_strategy(s2) context.do_strategy()


優點:
定義了一系列可重用的算法和行為
消除了一些條件語句
可以提供相同行為的不同實現
缺點:
客戶必須了解不同的策略

模板方法模式

內容:定義一個操作中的算法的骨架,而將一些步驟延遲到子類中。模板方法
使得子類可以不改變一個算法的結構即可重定義該算法的某些特定步驟。
角色:
抽象類(AbstractClass):定義抽象的原子操作(鉤子操作);實現一個模
板方法作為算法的骨架。
具體類(ConcreteClass):實現原子操作

from abc import ABCMeta, abstractmethod from time import sleepclass Window(metaclass=ABCMeta):@abstractmethoddef start(self):pass@abstractmethoddef repaint(self):pass@abstractmethoddef stop(self): # 原子操作/鉤子操作passdef run(self): # 模板方法self.start()while True:try:self.repaint()sleep(1)except KeyboardInterrupt:breakself.stop()class MyWindow(Window):def __init__(self, msg):self.msg = msgdef start(self):print("窗口開始運行")def stop(self):print("窗口結束運行")def repaint(self):print(self.msg)MyWindow("Hello...").run()


適用場景:
一次性實現一個算法的不變的部分
各個子類中的公共行為應該被提取出來并集中到一個公共父類中以
避免代碼重復
控制子類擴展

總結

以上是生活随笔為你收集整理的sjms-4 行为型模式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。