设计模式>>>观察者模式

#1、什么是观察者模式?

  观察者模式=(出版者+订阅者)模式,观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。这个主题对象在状态发生变化时,会通知所有观察者对象,使它们能够自动更新自己。

  例如:你有一个新闻APP,你订阅了《程序员》模块,当这个模块有新的文章更新时,你能在第一时间获取更新。当你厌倦了这个模块的内容时,取消订阅就行了。简单点理解就是:注册--->接收消息--->取消--->不在通知。

#2、具体如何使用?

  *2.1场景描述:目前需要开发一款新闻应用,用户订阅某个模块后,系统会主动给他发送这个模块的消息,用户取消订阅后,不在向该用户推送这个模块的消息。

  *2.2设计类图如下:

  

  *2.3类图描述

   抽象出版者(NewsService):抽象观察者模式的出版中心,注册订阅用户,存储订阅用户,删除订阅用户,新闻推送,可以类比为最基本的用户增删改查。

   具体出版者(NewsServiceImpl):出版中心的具体实现,为所有订阅的用户发送通知。

   抽象订阅者(UserService):抽象订阅者需要的新闻信息,展示方式。

     具体订阅者(UserOne):抽象订阅者的具体实现,自定义新闻的展示方式。   

#3、项目具体实现细节

   *3.1项目结构

  *3.2具体代码

1 public interface NewsService {
2     void registerNews(UserService userService);
3     void setNewsInfo(NewsBean newsBean);
4     void notifyNews();
5     void cancleNews(UserService userService);
6
7     void setState();
8     boolean getState();
9 }

  

1 public interface UserService {
2     void updateNews(NewsBean newsBean);
3     void displayNews();
4 }
 1 public class NewServiceImpl implements NewsService {
 2     private boolean state = false;
 3     private NewsBean newsBean;
 4     private List<UserService> userServiceList = null;
 5
 6     private List<UserService> getUserServiceList(){
 7         if(userServiceList ==null){
 8             userServiceList = new ArrayList<>();
 9         }
10         return userServiceList;
11     }
12
13     /**
14      * 初始化
15      */
16     public NewServiceImpl(){
17         getUserServiceList();
18     }
19
20     @Override
21     public void registerNews(UserService userService) {
22         userServiceList.add(userService);
23     }
24
25     @Override
26     public void cancleNews(UserService userService) {
27         userServiceList.remove(userService);
28     }
29
30     /**
31      * 通知所有订阅用户
32      */
33     @Override
34     public void notifyNews() {
35         for (UserService userService : userServiceList) {
36             userService.updateNews(newsBean);
37         }
38     }
39
40     /**
41      * 设置新闻信息
42      * @param newsBean
43      */
44     @Override
45     public void setNewsInfo(NewsBean newsBean){
46         this.newsBean = newsBean;
47         notifyNews();
48     }
49
50     @Override
51     public void setState() {
52         state = true;
53     }
54
55     @Override
56     public boolean getState() {
57         return this.state;
58     }
59 }
 1 public class UserOne implements UserService{
 2     private NewsService newsService;
 3     private NewsBean newsBean;
 4     /**
 5      * 订阅新闻
 6      * @param newsService
 7      */
 8     public UserOne(NewsService newsService){
 9         this.newsService = newsService;
10         newsService.registerNews(this);
11     }
12     @Override
13     public void updateNews(NewsBean newsBean) {
14         this.newsBean = newsBean;
15         displayNews();
16     }
17
18     @Override
19     public void displayNews() {
20         System.out.println(newsBean);
21     }
22 }
 1 public class UserTwo implements UserService{
 2     private NewsService newsService;
 3     private NewsBean newsBean;
 4     SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
 5
 6     /**
 7      * 订阅新闻
 8      * @param newsService
 9      */
10     public UserTwo(NewsService newsService){
11         this.newsService = newsService;
12         newsService.registerNews(this);
13     }
14     @Override
15     public void updateNews(NewsBean newsBean) {
16         this.newsBean = newsBean;
17         displayNews();
18     }
19
20     @Override
21     public void displayNews() {
22         System.out.println("\n>>>高级用户推送信息:"+"\n"+newsBean.getNewsTitle()+"\t"
23                 +sdf.format(newsBean.getNewsDate())+"\n"+newsBean.getNewsContent());
24     }
25 }

  

 1 public class NewsSystem {
 2
 3     public static void main(String[] args) {
 4         NewsService newsService = new NewServiceImpl();
 5         // 用户类型一
 6         UserOne userOne = new UserOne(newsService);
 7         // 用户类型二
 8         UserTwo userTwo = new UserTwo(newsService);
 9         // 新闻推送
10         newsService.setNewsInfo(new NewsBean("天道酬勤","习大大说:“天上不会掉馅饼," +
11                 "努力奋斗才能梦想成真。”",new Date()));
12         // 用户类型一 取消订阅
13         newsService.cancleNews(userOne);
14         // 又一次新闻推送
15         newsService.setNewsInfo(new NewsBean("观察者模式","观察者模式=(出版者+订阅者)" +
16                 "模式",new Date()));
17     }
18 }

  *3.3运行结果

  

#4、模式总结

    *4.1优点

    出版者和订阅者之间用松耦合的方式结合,订阅者不必关心出版者如何给自己推送消息;

    在对象之间定义一对多的依赖关系,对订阅者统一进行推送消息。

  *4.2适用场景

    当一个对象改变公共对象时,他不知道在其他什么地方用到这个公共对象。

转载请标明地址:http://www.cnblogs.com/huaxingtianxia/p/6266913.html

  

    

时间: 2024-12-15 07:10:20

设计模式>>>观察者模式的相关文章

【转】设计模式-观察者模式

设计模式-观察者模式 定义 观察者模式(有时又被称为发布-订阅Subscribe>模式.模型-视图View>模式.源-收听者Listener>模式或 从属者模式)是软件设计模式的一种.在此种模式中,一个目标物件管理所有相依于它的观察者物件,并且在它本身的状态改变时主动发出通知.这通常透过呼叫各 观察者所提供的方法来实现.此种模式通常被用来实现事件处理系统. 基本简介 观察者模式(Observer)完美的将观察者和被观察的对象分离开.举个例子,用户界面可以作为一个观察者,业务 数据是被观察

设计模式 - 观察者模式(Observer Pattern) 详解

观察者模式(Observer Pattern) 详解 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26583157 版权所有, 禁止转载, 如有转载, 请站内联系. 观察者模式(Observer Pattern): 定义了对象之间的一对多的依赖, 这样一来, 当一个对象改变状态时, 它的所有依赖者都会收到通知并自动更新. 使用方法: 1. 首先新建主题(subject)接口, 负责注册(register)\删除(remove

设计模式 - 观察者模式(Observer Pattern) Java内置 使用方法

观察者模式(Observer Pattern) Java内置 使用方法 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26601659 观察者模式(observer pattern)详解, 参见: http://blog.csdn.net/caroline_wendy/article/details/26583157 Java内置的观察者模式, 是通过继承父类, 实现观察者模式的几个主要函数: Observerable(可被观

C#设计模式---观察者模式简单例子

在开发过程中经常遇到一个模块中的 一个方法调用了其他模块中相关的方法 比如说在一个系统中,如果出现了错误,就调用专门进行错误处理的模块中的方法进行错误处理 而因为错误处理的操作有很多,所以将这些具体的操作封装在其他的模块中 在专门进行错误处理的模块中调用其他模块中的错误操作方法 这样一来在主系统中只要实例化专门进行错误处理的模块对象 并调用其相关的方法,其他模块中的具体方法也都会被执行 这时专门进行错误处理的模块被称为发布者 其他拥有具体错误操作的模块称为订阅者 只要发布者一发布信息(方法被调用

java设计模式--观察者模式和事件监听器模式

文章转载于:http://www.java2000.net/p9452 复习设计模式,看到observer观察者模式,说法是该模式和iterator迭代器模式类似已经被整合进jdk,但是jdk提供了两种接口: 一.java.util.Observer -- 观察者接口 对应: java.util.Observable --受查者根类 二.java.util.EventListener -- 事件监听/处理接口 对应: java.util.EventObject -- 事件(状态)对象根类 研究了

学习设计模式--观察者模式(C++)

1. 说说简单的函数回调 首先说说一种简单的函数回调机制(一种通过获取对象的指针来进行函数的调用方法)以下是代码演示--- 这是观察者(被回调)部分: class Observer { public: // 抽象观察者的纯虚函数 virtual void UpdateMessage() = 0; }; class ConcreteObserver : public Observer { public: // 实现抽象类的纯虚函数 void UpdateMessage(); } void Conc

大话设计模式观察者模式

从前,有个放羊娃,每天都去山上放羊,一天,他觉得十分无聊,就想了个捉弄大家寻开心的主意.他向着山下正在种田的农夫们大声喊:"狼来了!狼来了!救命啊!"农夫们听到喊声急忙拿着锄头和镰刀往山上跑,他们边跑喊:"不要怕,孩子,我们来帮你打恶狼!"农夫们气喘吁吁地赶到山上一看,连狼的影子也没有!放羊娃哈哈大笑:"真有意思,你们上当了!"农夫们生气地走了.第二天,放羊娃故伎重演,善良的农夫们又冲上来帮他打狼,可还是没有见到狼的影子.放羊娃笑得直不起腰:&q

head first 设计模式 观察者模式

Head first 设计模式:定义了对象之间的一对多依赖,这样一来,当一个对象改变状态时,它的所有依赖者都会受到通知并自动更新.   让主题与观察者之间松耦合 大话设计模式:定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象.这个主题对象在状态发生变化时,会通知所有观察者对象,使它们能够自动更新自己. 设计模式:描述了如何建立这种关系.这一模式中的关键对象是  目标(subject)和观察者(observer).一个目标可以有任意数目的依赖他的观察者.一旦目标的状态发生改变,所

一口一个设计模式--观察者模式

5月初,我们三个小伙伴开始着手准备机房收费系统合作版,借此大好良机,我准备把设计模式写成一个博客专栏,站在一个更高的角度品味前人的思想精髓.设计模式分为三类--创建型.结构型.行为型,咱们就先从行为型模式--观察者模式开讲. 开讲之前,我先给大家讲个小故事,以便大家快速认识观察者模式.在战争年代,战争双方不时受到敌军飞机的轰炸,于是人们发明了航空警报,并派几个侦察兵放哨,一但敌机来临,立即拉响航空警报,这样所有的收听者就能听到报警逃跑.上述情节,看似平常,其实是观察者模式是完美体现.下图是针对上

18. 星际争霸之php设计模式--观察者模式

题记==============================================================================本php设计模式专辑来源于博客(jymoz.com),现在已经访问不了了,这一系列文章是我找了很久才找到完整的,感谢作者jymoz的辛苦付出哦! 本文地址:http://www.cnblogs.com/davidhhuan/p/4248205.html ===========================================