-
内容:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变的时候,所有依赖于它的对象得到通知并被自动更新。观者者模式又称为"发布-订阅"模式。比如天气预报,气象局分发气象数据。
-
角色:
- 抽象主题(Subject)
- 具体主题(ConcreteSubject)------发布者
- 抽象观察者(Observer)
- 具体观察者(ConcreteOserver)------订阅者
-
举个例子
需求:公司可以向每个订阅的员工发送消息,员工可以选择需不需要订阅
python
from abc import ABCMeta,abstractmethod
# 定义顶层代码
# 抽象订阅者
class Observer(metaclass=ABCMeta):
@abstractmethod
def update(self,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 StaffNitice(Notice):
def __init__(self,company_info=None):
super().__init__()
# 处理成私有对象
self.__company_info=company_info
# 类似于get
@property
def company_info(self):
return self.__company_info
# 类似于set
@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
notice=StaffNitice("初始公司信息")
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)
- 适用场景;
- 当一个抽象模型有两个方面,其中一个依赖于另外一个方面。将这两者封装在独立对对象中以使他们可以各自独立地改变和复用。
- 当一个对象的改变需要同时改变其他对象,而不知道具体有多少对象有待改变。
- 当一个对象必须通知其他对象,而它又不能假定其他对象是谁。换言之,你不希望这些对象紧密耦合的。
- 优点:
- 目标和观察者之间的抽象耦合最少
- 支持广播通信