Python设计模式

第一章: 设计模式基础

第二章: 常用设计模式

首页 > Python设计模式 > 第二章: 常用设计模式 > 2.6节: 观察者模式

2.6节: 观察者模式

薯条老师 2021-10-03 17:06:55 364368 0

编辑 收藏

广州番禺Python, Java小班周末班培训

薯条老师在广州做Python和Java的小班培训,一个班最多10人,学员的平均就业薪资有11K。不在广州的同学可以报名线上直播班,跟线下小班的同学们同步学习。培训的课程有Python爬虫,Python后端开发,Python办公自动化,Python大数据分析,Python量化投资,Python机器学习,Java中高级后端开发。授课详情请点击:http://chipscoco.com/?cate=6

2.6.1 观察者模式

观察者模式定义了对象间的一种一对多的依赖关系,当一个对象(主题)的状态发生改变时,则所有依赖于它的对象(观察者)都会得到通知并被自动更新。

2.6.2 观察者模式与发布订阅模式

观察者模式解决了被观察者对象和观察者对象的紧耦合问题,也即,如果不使用观察者模式,通常的实现是将状态耦合在观察者对象的内部。

observer.png

发布订阅模式是对观察者模式的推广,在主题和观察者之间引入了一个中间层。有了中间层以后,主题的状态一旦变更,消息被直接发送给中间层,而非观察者。在实际开发中,通常使用消息队列来做发布订阅模式中的中间层。

subscribe.png

2.6.3 适用场景

当对象的行为依赖于目标对象的状态时,就应当使用观察者模式,以微信公众号为例:微信用户关注了某公众号,当公众号推文时,系统会自动通知所有用户去阅读。观察者模式的具体实现可参考下小节的源码实现。

2.6.4 源码实现

# __author__ = 薯条老师,微信公众号:薯条编程

"""
观察者模式定义了对象间的一种一对多的依赖关系。
观察者的四种角色:
(1) Subject:抽象主题类 ,用来提供添加。删除,通知观察者的抽象接口
(2) Concrete Subject:具体的主题子类,用来实现抽象主题中的抽象接口
(3) Observer:抽象观察者类 ,用来定义一个抽象的行为
(4) Concrete Observer:具体的观察者子类,实现抽象观察者的抽象接口,当主题状态变更时,
会自动调用该接口
"""

import abc
"""
(1) 定义一个名为公众号的抽象主题类,该抽象基类包含三个抽象接口:
add_user:添加已关注的用户
notify: 状态变更时,通知所有已关注的用户阅读  
"""

class OfficialAccount(abc.ABC):
    @abc.abstractmethod
    def add_user(self, user):
        pass
        
        
    @abc.abstractmethod
    def notify(self):
        pass

                
"""
(2) 定义一个名为微信公众号的主题子类
"""
class WechatOfficialAccount(OfficialAccount):
    def __init__(self):
        self.__users = []
        self.__message = None
        
        
    def add_user(self, user):
        self.__users.append(user)
        
        
    def notify(self):
        if self.__message is not None:
            [user.read(self.__message) for user in self.__users]
            
            
    def push(self, message):
        self.__message = message
        self.notify()
        self.__message = None
        
        
"""
(3) 定义一个抽象观察者类User,该抽象基类包含一个抽象接口:
read: 阅读推文
"""
class User(abc.ABC):
    @abc.abstractmethod
    def read(self, message):
        pass
        
        
"""
(4) 定义一个具体观察者子类WechatUser
"""
class WechatUser(User):
    def __init__(self, name):
        self.__name = name
        
        
    def read(self, message):
        print("{} received message:{}".format(self.__name, message))
        
        
if __name__ == "__main__":
    wechatOfficialAccount = WechatOfficialAccount()
    kitty = WechatUser("kitty")
    lisa = WechatUser("Lisa")
    wechatOfficialAccount.add_user(kitty)
    wechatOfficialAccount.add_user(lisa)
    wechatOfficialAccount.push("欢迎来到单身狗俱乐部")

2.6.5 最具实力的小班培训

薯条老师在广州做Python和Java的小班培训,一个班最多10人。不在广州的同学可以报名线上直播班,跟线下小班的同学们同步学习。打算参加小班培训的同学,必须遵守薯条老师的学习安排,认真做作业和项目。把知识学好,学扎实,那么找到一份高薪的工作就是很简单的一件事。

(1) Python后端工程师高薪就业班,月薪11K-18K,免费领取课程大纲
(2) Python爬虫工程师高薪就业班,年薪十五万,包拿Offer
(3) 数据分析高薪就业班,月薪11K-15K, 免费领取课程大纲
(4)
Python大数据挖掘,量化投资就业班,月薪12K-25K,免费领取课程大纲

扫码免费领取Python学习资料:


欢迎 发表评论: