12.python设计模式【观察者模式】

  • 内容:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变的时候,所有依赖于它的对象得到通知并被自动更新。观者者模式又称为"发布-订阅"模式。比如天气预报,气象局分发气象数据。

  • 角色:

    • 抽象主题(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)
  • 适用场景;
    • 当一个抽象模型有两个方面,其中一个依赖于另外一个方面。将这两者封装在独立对对象中以使他们可以各自独立地改变和复用。
    • 当一个对象的改变需要同时改变其他对象,而不知道具体有多少对象有待改变。
    • 当一个对象必须通知其他对象,而它又不能假定其他对象是谁。换言之,你不希望这些对象紧密耦合的。
  • 优点:
    • 目标和观察者之间的抽象耦合最少
    • 支持广播通信
相关推荐
2601_9516437713 分钟前
Python第一,Java跌出前三,C语言杀回来了
java·c语言·python·编程语言排行·技术趋势
AC赳赳老秦2 小时前
OpenClaw+Power Apps 实战:自动生成 Power Apps 应用、连接 Excel 数据源
大数据·开发语言·python·serverless·excel·deepseek·openclaw
geovindu3 小时前
go: Generators Pattern
开发语言·后端·设计模式·golang·生成器模式
茉莉玫瑰花茶4 小时前
综合案例 - AI 智能租房助手 [ 5 ]
服务器·数据库·人工智能·python·ai
文艺倾年4 小时前
【强化学习】强化学习基本概念,20W字总结(一)
人工智能·python·语言模型·自然语言处理·面试·职场和发展·大模型
宸丶一4 小时前
Day 13:持久化记忆 - 让 Agent 拥有长期记忆
jvm·python·ai
码云骑士5 小时前
13-列表append的底层真相(上)-listobject源码中的预分配策略
开发语言·python
浦信仿真大讲堂5 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
xufengzhu5 小时前
第三方 Python 库 Loguru 的进阶实战
python·loguru
极光代码工作室6 小时前
基于深度学习的手写数字识别系统
人工智能·python·深度学习·神经网络·机器学习