观察者模式

'''
OBSERVER——观察者模式?
  想知道咱们公司最新MM情报吗?加入公司的MM情报邮件组就行了,tom负责搜集情报,他发现的新情报不用一个一个通知我们,直接发布给邮件组,我们作为订阅者(观察者)就可以及时收到情报啦  
  观察者模式:观察者模式定义了一种一队多的依赖关系,让多个观察者对象同时监听某一个主题对象。这个主题对象在状态上发生变化时,会通知所有观察者对象,使他们能够自动更新自己。   


容:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时, 所有依赖于它的对象都得到通知并被自动更新。观察者模式又称“发布-订阅”模式
角色:


抽象主题(Subject)
具体主题(ConcreteSubject)——发布者
抽象观察者(Observer)
具体观察者(ConcreteObserver)——订阅者
适用场景:


当一个抽象模型有两方面,其中一个方面依赖于另一个方面。将这两者封装在独立对象中以使它们可以各自独立地改变和复用。
当对一个对象的改变需要同时改变其它对象,而不知道具体有多少对象有待改变。
当一个对象必须通知其它对象,而它又不能假定其它对象是谁。换言之,你不希望这些对象是紧密耦合的。
优点:


目标和观察者之间的抽象耦合最小
支持广播通信
缺点:


多个观察者之间互不知道对方存在,因此一个观察者对主题的修改可能造成错误的更新



from abc import ABCMeta
from abc import abstractmethod


class Observer(metaclass=ABCMeta):
    @abstractmethod
    def update(self,company_info):
        pass




class Notice(object):
    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 obj in self.observers:
            obj.update(self)


class ManagerNotice(Notice):
    def __init__(self,company_info=None):
        super().__init__()
        self.__company_info=company_info


    def detach(self,obs):
        super().detach(obs)
        obs.company_info=None


    @property
    def company_info(self):
        return self.__company_info


    @company_info.setter
    def company_info(self,info):
        self.__company_info=info
        self.notify()




class Manager(Observer):
    def __init__(self):
        self.company_info=None


    def update(self,noti):
        self.company_info=noti.company_info


notice=ManagerNotice()
alex = Manager()
wusir = Manager()


print(alex.company_info)
print(wusir.company_info)


notice.attach(alex)
notice.attach(wusir)
notice.company_info = "公司运行良好"


print(alex.company_info)
print(wusir.company_info)


notice.company_info = "公司将要上市"


print(alex.company_info)
print(wusir.company_info)


notice.detach(wusir)


notice.company_info = "公司要破产了,赶快跑路"


print(alex.company_info)
print(wusir.company_info)


notice.company_info = "公司已经破产了"


print(alex.company_info)
print(wusir.company_info)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值