Python:设计模式之观察者模式

简介: Python:设计模式之观察者模式

三类模式


1、创建型模式:基于对象的创建机制。隔离了对象的创建细节,使得代码能够与要创建的对象的类型相互独立

2、结构型模式:用于设计对象和类的结构,从而使他们可以相互协作以获得更大的结构,

重点关注的是简化结构和识别类和对象之间的关系

3、行为型模式:主要关注对象的责任。用来处理对象之间交互,以实现更大的功能

行为型模式建议:对象之间应该能够彼此交互,同时还应该是松耦合的


观察者模式


观察者设计模式中,对象(主题)维护了一个依赖(观察者)列表,

以便主题可以使用观察者定义的任何方法通知所有观察者,它所发生的变化


例如:

广播或发布/订阅系统


观察者模式的主要目标


1、定义了对象之间的一对多的依赖关系,从而使得一个对象中的任何更改都将自动通知给其他依赖对象

2、封装了主题的核心组件


观察者模式的应用场景


1、在分布式系统中实现事件服务

2、用作新闻机构的框架

3、股票市场也是观察者模式的一个大型场景


代码实现

# -*- coding: utf-8 -*-

# 主题
class Subject(object):
    def __init__(self):
        self.__observers = []

    def register(self, observer):
        self.__observers.append(observer)

    def notify_all(self, message):
        for observer in self.__observers:
            observer.notify(self, message)


from abc import ABC, abstractmethod


# 观察者
class IObserver(ABC):
    @abstractmethod
    def notify(self, subject, message):
        pass


# 具体观察者
class Observer1(IObserver):
    def notify(self, subject, message):
        print("Observer1 收到{}主题消息: {}".format(type(subject).__name__, message))


class Observer2(IObserver):
    def notify(self, subject, message):
        print("Observer2 收到{}主题消息: {}".format(type(subject).__name__, message))


if __name__ == '__main__':
    observer1 = Observer1()
    observer2 = Observer2()

    subject = Subject()
    subject.register(observer1)
    subject.register(observer2)

    subject.notify_all("通知:3:00开会")
    """
    Observer1 收到Subject主题消息: 通知:3:00开会
    Observer2 收到Subject主题消息: 通知:3:00开会
    """

观察者模式有3个主要角色:

1、主题:主题需要了解观察者,提供注册方法,一个主题可以处理多个观察者

2、观察者:为关注主题的对象定义一个接口,定义了观察者需要实现的各个方法,

以便在主题发生时能够活着相应通知

3、具体观察者:实现了观察者接口以保持其状态与主题中的变化相一致


具体流程:

具体观察者通过实现观察者提供的接口向主题注册自己,

每当状态发生变化时,该主题都会使用观察者提供的通知方法来通告所有具体观察者


观察者模式的通知方式

1、拉模式:观察者扮演积极角色,主题变化->广播给已注册的观察者->观察者获取相应的变化情况

2、推模式:主题起主导作用,变化由主题推送到观察者


耦合:一个对象对于与其交互的其他对象的了解程度

松耦合:降低多个对象之间的依赖性


观察者模式的优点


1、使得彼此交互对象之间保持松耦合

2、我们可以在无需对主题或者观察者进行任何修改的情况下高效地发送数据到其他对象

3、随时添加/删除观察者


观察者模式的缺点


1、观察者接口必须由具体观察者实现,而涉及继承,无法进行组合,因为观察者接口可以实例化

2、如果实现不当,观察者可能回增加复杂性,并且导致性能降低

3、在软件应用程序中,通知有时可能不可靠,并导致竞争条件或不一致性

            </div>
目录
相关文章
|
设计模式 Python
Python:设计模式之观察者模式
Python:设计模式之观察者模式
97 0
|
设计模式 算法 Python
Python:设计模式之模板模式
Python:设计模式之模板模式
59 0
|
设计模式 Python
Python:设计模式之门面模式
Python:设计模式之门面模式
89 0
|
设计模式 Python
Python:设计模式之状态模式
Python:设计模式之状态模式
155 0
|
弹性计算 编解码 负载均衡
阿里云实人认证身份认证流量包降价20-30%
阿里云实人认证身份认证流量包降价20-30%,阿里云产品大规模调价,核心云产品价格全线下调,技术红利释放核心产品最高降幅50%,以下产品的价格调整将于2023年5月7日生效,最终以产品详情页实际情况为准,阿里云百科分享阿里云官网发布的降价产品及降价幅度说明:
215 0
|
Python
python设计模式(二十):观察者模式
观察者模式,核心抽象对象管理所有依赖他的其他类,并在设计中使其在发生变动时,主动通知并更新其他类;也叫模型-视图模式、源-收听者模式、从属者模式。 该模式必须包含两个角色:观察者和被观察对象。在刚才的例子中,业务数据是被观察对象,用户界面是观察者。
1078 0
|
Python 设计模式
python设计模式(八):装饰模式
装饰模式指的是在不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。 在Python种实现动态扩展对象功能的方法,最简单的是通过复写__getattr__函数,在getattr种写入我们需要扩展的功能,实例代码如下: 特点 (1) 装饰对象和真实对象有相同的接口。
966 0
|
传感器 消息中间件 Python
19、Python与设计模式--观察者模式
#一、火警报警器(2) 在门面模式中,我们提到过火警报警器。在当时,我们关注的是通过封装减少代码重复。而今天,我们将从业务流程的实现角度,来再次实现该火警报警器。 ``` class AlarmSensor: def run(self): print "Alarm Ring..." class WaterSprinker: def run(self):
4691 0
下一篇
无影云桌面