更多信息请参考 【设计模式】
观察者模式内容
定义对象间的一种一对多的依赖关系,当一个对象的状态发生变化时,所有依赖它的对象都得到通知并被自动更新,观察者模式又被称为“发布-订阅”模式
观察者模式中的橘色
- 抽象主题(Subject)
- 具体主题(Concrete Subject)----发布者
- 抽象观察者(Observer)
- 具体观察者(Concrete Observer)----订阅者
观察者模式适应场景
- 当一个抽象模型有两方面,其中一个方面依赖于另一个方面,将这两者封装在独立对象中以使各自独立地改变和服用
- 当对一个对象的改变需要同时改变其他对象,而不知道具体有多少对象有待改变
- 当一个对象必须通知其他对象,而它又不能嘉定其他对象是谁,换言之,你不希望这些对象是紧密耦合的
观察者模式优点
- 目标和观察者之间的抽象耦合最小
- 支持广播通信
观察者模式实例
代码如下:
from abc import ABCMeta,abstractmethod
class Observer(metaclass=ABCMeta):
@abstractmethod
def update(self,notice): # notice shi Notice类的对象
pass
class 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):
super().__init__()
self.__company_info=company_info
@property
def company_info(self):
return self.__company_info
@company_info.setter
def company_info(self,info):
self.__company_info=info
self.notify()
class Staff(Observer):
def __init__(self):
self.company_info=None
def update(self,notice):
self.company_info=notice.company_info
if __name__=="__main__":
notice=StaffNotice("初始公司信息")
s1=Staff()
s2=Staff()
notice.attach(s1)
notice.attach(s2)
notice.company_info="公司今年业绩非常好,给大家发奖金..."
print(s1.company_info)
print(s2.company_info)
notice.detach(s1)
notice.company_info = "公司今天放假。。。"
print(s1.company_info)
print(s2.company_info)
执行结果如下:
公司今年业绩非常好,给大家发奖金...
公司今年业绩非常好,给大家发奖金...
公司今年业绩非常好,给大家发奖金...
公司今天放假。。。