写在前面

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

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

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

观察者模式警匪电影版

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

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. scrapy 发送post请求

    登录人人网为例 1.想要发送post请求,那么使用'scrapy.FormRequest'方法,可以方便的指定表单数据 2.如果想在爬虫一开始的时候就发送post请求,那么应该重写'start_req ...

  2. MS-DOS 6.22 +Vim+masm 汇编环境

    安装vim 个人习惯用 vim 编辑,因此稍微折腾了一下.不用这么麻烦直接用 edit 编辑也是可以的. 原来安装的 MS-DOS 7.10 虚拟机安装好vim后无法运行,所以改用了 MS-DOS 6 ...

  3. 实验六 MapReduce实验:二次排序

    实验指导: 6.1 实验目的基于MapReduce思想,编写SecondarySort程序. 6.2 实验要求要能理解MapReduce编程思想,会编写MapReduce版本二次排序程序,然后将其执行 ...

  4. 【BZOJ3451】Normal (点分治)

    [BZOJ3451]Normal (点分治) 题面 BZOJ 题解 显然考虑每个点的贡献.但是发现似乎怎么算都不好计算其在点分树上的深度. 那么考虑一下这个点在点分树中每一次被计算的情况,显然就是其在 ...

  5. Linux网络基础-总

    目录 Linux网络基础 一.网卡和数据包的转发 1.收包流程 二.多网卡bonding 三.SR-IOV 四.DPDK 五.TUN/TAP 六.Linux bridge 和VLAN 七.TCP/IP ...

  6. css border制作小三角形状及气泡框(兼容IE6)

    先看下CSS盒模型 一个盒子包括: margin+border+padding+content 上下左右边框交界处出呈现平滑的斜线. 利用这个特点, 通过设置不同的上下左右边框宽度或者颜色可以得到小三 ...

  7. Codeforces Round #533 (Div. 2) C.思维dp D. 多源BFS

    题目链接:https://codeforces.com/contest/1105 C. Ayoub and Lost Array 题目大意:一个长度为n的数组,数组的元素都在[L,R]之间,并且数组全 ...

  8. Golang Kernel For Jupyter-NoteBook

    上篇回顾:VSCode and NoteBook for JavaScript 正常流程 安装Go语言:sudo apt install golang 安装内核的相关依赖包:sudo apt inst ...

  9. nodejs的某些api~(二)crypto加密模块

    就随便写写crypto模块,加密在node里面挺重要的,特别是密码,用户名都用crypto加密,在我写的那个作品里面,用户名密码的存储都是用crypto加密的,也没有深究里面的内容,想深究的同学可以看 ...

  10. HDU--4825 Xor Sum (字典树)

    题目链接:HDU--4825 Xor Sum mmp sb字典树因为数组开的不够大一直wa 不是报的 re!!! 找了一下午bug 草 把每个数转化成二进制存字典树里面 然后尽量取与x这个位置上不相同 ...