写在前面

钩子函数、注册函数、回调函数,他们的概念其实是一样的。

观察者模式,又可以称之为发布-订阅模式,观察者,顾名思义,就是一个监听者,类似监听器的存在,一旦被观察/监听的目标发生的情况,就会被监听者发现,这么想来目标发生情况到观察者知道情况,其实是由目标奖情况发送到观察者的。

  观察者模式多用于实现订阅功能的场景,例如微博的订阅,当我们订阅了某个人的微博账号,当这个人发布了新的消息,就会通知我们。

观察者模式警匪电影版

观察者接口 (观察者可能是警察,也可能是线人)

public interface Observer {
void report(String message,String name);
}

观察者实现类 (警察)

public class Policeman implements Observer {
private String name;
Policeman(String name){this.name = name;}
@Override
public void report(String message, String name) {
System.out.println(this.name+"发现"+name+":"+message);
}
}

观察者实现类(线人)

public class Informers implements Observer {
private String name;
Informers(String name){this.name = name;}
@Override
public void report(String message, String name) {
System.out.println(this.name+"发现"+name+":"+message);
}
}

被观察者(坏人) 接口 (具体可能是 小偷,毒贩等。。。)

public interface BadGuy {
void addObserver(Observer observer);
void removeObserver(Observer observer);
void doSomething(String message);
}

小偷


import java.util.Queue;
import java.util.concurrent.LinkedBlockingQueue; public class Thief implements BadGuy {
Queue<Observer> queue = new LinkedBlockingQueue<Observer>();
private String name;
Thief(String name){this.name = name;}
@Override
public void addObserver(Observer observer) {
if(!queue.contains(observer)){
queue.add(observer);
}
} @Override
public void removeObserver(Observer observer) {
if(queue.contains(observer)){
queue.remove(observer);
}
} @Override
public void doSomething(String message) {
System.out.println(this.name+" : "+message);
for(Observer observer:queue){
observer.report(message,this.name);
}
}
}

毒贩

import java.util.Queue;
import java.util.concurrent.LinkedBlockingQueue; public class Dealer implements BadGuy {
private String name;
Dealer(String name){this.name = name;}
Queue<Observer> queue = new LinkedBlockingQueue<Observer>();
@Override
public void addObserver(Observer observer) {
if(!queue.contains(observer)){
queue.add(observer);
}
} @Override
public void removeObserver(Observer observer) {
if(queue.contains(observer)){
queue.remove(observer);
}
} @Override
public void doSomething(String message) {
System.out.println(this.name+":"+message);
for(Observer observer:queue){
observer.report(message,this.name);
}
}
}

最后测试一下


public class ObserverDemo {
public static void main(String [] args){
Observer policeman = new Policeman("李警官");
Observer informers = new Informers("线人A");
BadGuy thief = new Thief("小偷甲");
BadGuy dealer = new Dealer("毒贩阿尔法"); thief.addObserver(policeman);
thief.addObserver(informers);
thief.doSomething("此处人傻钱多速来"); dealer.addObserver(policeman);
dealer.addObserver(informers);
dealer.doSomething("新货已到达...");
//线人被毒贩发现被干掉
dealer.removeObserver(informers);
dealer.doSomething("线人被干掉了!");
//警察被毒贩发现牺牲了
dealer.removeObserver(policeman);
dealer.doSomething("警察也牺牲了!");
dealer.doSomething("现在我可以无法无天了。。。哈哈哈哈!!!");
new Runnable() {
@Override
public void run() {
try{
Thread.sleep(1000);
System.out.println("天降正义!!! 毒贩被一位不愿意透露姓名的大佬带走。。。");
}
catch(InterruptedException e){
e.printStackTrace();
} }
}.run();
}
}

结果

小偷甲 : 此处人傻钱多速来
李警官发现小偷甲:此处人傻钱多速来
线人A发现小偷甲:此处人傻钱多速来
毒贩阿尔法:新货已到达...
李警官发现毒贩阿尔法:新货已到达...
线人A发现毒贩阿尔法:新货已到达...
毒贩阿尔法:线人被干掉了!
李警官发现毒贩阿尔法:线人被干掉了!
毒贩阿尔法:警察也被干掉了!
毒贩阿尔法:现在我可以无法无天了。。。哈哈哈哈!!!
天降正义!!! 毒贩被一位不愿意透露姓名的大佬带走。。。

总结

 关键点:

    1、针对观察者与被观察者分别定义接口,有利于分别进行扩展。

    2、重点就在被观察者的实现中:

      (1)定义观察者集合,并定义针对集合的添加、删除操作,用于增加、删除订阅者(观察者)

      (2)定义通知方法,用于将新情况通知给观察者用户(订阅者用户)

    3、观察者中需要有个接收被观察者通知的方法。

观察者模式--java的更多相关文章

  1. 设计模式之第18章-观察者模式(Java实现)

    设计模式之第18章-观察者模式(Java实现) 话说曾小贤,也就是陈赫这些天有些火,那么这些明星最怕的,同样最喜欢的是什么呢?没错,就是狗仔队.英文的名字比较有意思,是paparazzo,这一说法据说 ...

  2. 观察者模式——java设计模式

    观察者模式 定义:观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象.这个主题对象在状态上发生变化时,会通知所有观察者对象,使它们能够自动更新自己. 1.观察者模式的结构 ( ...

  3. 观察者模式/ java实现附代码 /

    /注:场景和例子引用github上的设计模式.传送门:https://github.com/iluwatar/java-design-patterns/tree/master/observer 场景: ...

  4. 设计模式01观察者模式(java)

    先发代码,有空来写内容. observer1 import java.util.Observer; import java.util.Observable; //学生类(Student)继承Obser ...

  5. 观察者模式--java jdk中提供的支持

    一.简介 观察者设计模式有如下四个角色 抽象主题角色:把所有对观察者对象的引用保存在一个集合中,每个抽象主题角色都可以有任意数量的观察者.抽象主题提供一个接口,可以增加和删除观察者角色.一般用一个抽象 ...

  6. 观察者模式 - Java 实现1(使用JDK内置的Observer模式)

    使用JDK内置的观察者模式 1. 可观察者(主题) 被观察的主题继承 Observable 对象, 使用该对象的调用 notifyObservers() 或 notifyObservers(arg) ...

  7. 观察者模式——Java实例

    一.定义 观察者模式(有时又被称为模型-视图(View)模式.源-收听者(Listener)模式或从属者模式)是软件设计模式的一种.观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个 ...

  8. 观察者模式(Java实现)

    import java.util.ArrayList; import java.util.Iterator; /* 抽象观察者类 */ abstract class Observer { public ...

  9. ObserverPattern(观察者模式)-----Java/.Net

    当对象间存在一对多关系时,则使用观察者模式(Observer Pattern).比如,当一个对象被修改时,则会自动通知它的依赖对象.观察者模式属于行为型模式

随机推荐

  1. 2018-01微信小程序--直播

    一. 小程序直播支持的格式 目前小程序支付两种格式直播 1) flv格式直播 2) rtmp格式直播 二. 能够开通小程序直播的行业类目 由于直播需要资质, 并不是每个企业都能够开通小程序直播, 微信 ...

  2. 微信小程序API 文档快速参考索引

    内容那么多,这个页面到底做了什么? 第一:解决微信文档APi文档使用不便: 第二:解决了内容搜索与索引:—— 最好是写成全文索引文档,但是比较需要时间,而且更新是一件麻烦的事:所以以下是直接 连接官网 ...

  3. Hdoj 1115.Lifting the Stone 题解

    Problem Description There are many secret openings in the floor which are covered by a big heavy sto ...

  4. [BJOI2012]最多的方案(记忆化搜索)

    第二关和很出名的斐波那契数列有关,地球上的OIer都知道:F1=1, F2=2, Fi = Fi-1 + Fi-2,每一项都可以称为斐波那契数.现在给一个正整数N,它可以写成一些斐波那契数的和的形式. ...

  5. hdu 3746 Cyclic Nacklace(kmp最小循环节)

    Problem Description CC always becomes very depressed at the end of this month, he has checked his cr ...

  6. 20165223 week3蓝墨云测试总结

    1. 表达式0xaa | 0x55的值为 答案: 解析: 0xaa用二进制表示为10101010,0x55用二进制表示为01010101,按位或后为11111111,十进制表示为255,十六进制表示为 ...

  7. 牛客网Wannafly挑战赛25A 因子(数论 素因子分解)

    链接:https://www.nowcoder.com/acm/contest/197/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5242 ...

  8. 点击a标签不跳转的办法

    方法1: <a href="http://www.baidu.com" onclick="return false"></a> 方法2: ...

  9. Java Scanner篇

    Scanner 翻译解释为扫描器 Java中用于控制台的的数据输入 包:import java.util.Scanner 使用方法:Scanner reader=new Scanner(System. ...

  10. 第二十节,使用RNN网络拟合回声信号序列

    这一节使用TensorFlow中的函数搭建一个简单的RNN网络,使用一串随机的模拟数据作为原始信号,让RNN网络来拟合其对应的回声信号. 样本数据为一串随机的由0,1组成的数字,将其当成发射出去的一串 ...