欢迎光临散文网 会员登陆 & 注册

第20章观察者模式

2022-02-20 20:58 作者:取悦疾风  | 我要投稿

内容来自尚硅谷Java设计模式(图解+框架源码剖析)_哔哩哔哩_bilibili

写在前面:本文内容大致和原视频内老师的笔记内容相同,会偶尔插入自己的注释和理解,尽量会完成作业

兄弟们!学就完事了!加油!奥里给!

第20章观察者模式

20.1天气预报项目需求,具体要求如下

1)      气象站可以将每天测量到的温度,湿度,气压等等以公告的形式发布出去(比如发布到自己的网站或第三方)。需要设计开放型API,便于其他第三方也能接入气象站获取数据。

2)      提供温度、气压和湿度的接口

3)      测量数据更新时,要能实时的通知给第三方

 

20.2天气预报设计方案 1-普通方案

20.2.1WeatherData类

传统的设计方案

代码实现

Ø  问题分析

其他第三方接入气象站获取数据的问题

无法在运行时动态的添加第三方(新浪网站)

违反ocp原则->观察者模式

在WeatherData中,当增加一个第三方,都需要创建一个对应的第三方的公告板对象,并加入到dataChange,不利于维护,也不是动态加入

public void dataChange(){

        //调用接入方的update方法

        currentConditions.update(getTemperature(),getPressure(),getHumidity());

}

 

20.3观察者模式的基本原理

1)      观察者模式类似订牛奶业务

2)      奶站/气象局:Subject

3)      用户/第三方网站:Observer

Ø  Subject:登记注册、移除和通知

1)      registerObserver注册

2)      removeObserver移除

3)      notifyObservers()通知所有的注册的用户,根据不同需求,可以是更新数据,让用户来取,也可能是实施推送,看具体需求定

Ø  Observer:接收输入

Ø  观察者模式:对象之间多对一依赖的一种设计方案,被依赖的对象为Subject,依赖的对象为Observer,Subject通知Observer变化,比如这里的奶站是Subject,是1的一方。用户时Observer,是多的一方。

20.4观察者模式解决天气预报需求

20.4.1类图说明

20.4.2代码实现

20.4.3观察者模式的好处

1)      观察者模式设计后,会以集合的方式来管理用户(Observer),包括注册,移除和通知。

2)      这样,我们增加观察者(这里可以理解成一个新的公告板),就不需要去修改核心类WeatherData不会修改代码,遵守了ocp原则。

20.5观察者模式在Jdk应用的源码分析

1)      Jdk的 Observable类就使用了观察者模式

2)      代码分析+模式角色分析

Observable的作用和地位等价于我们前面讲过Subject

Observable是类,不是接口,类中已经实现了核心的方法 ,即管理Observer的方法 add..delete ..notify...

Observer 的作用和地位等价于我们前面讲过的Observer,有update

Observable 和Observer的使用方法和前面讲过的一样,只是Observable是类,通过继承来实现观察者模式


第20章观察者模式的评论 (共 条)

分享到微博请遵守国家法律