写在前面

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

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

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

观察者模式警匪电影版

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

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. php获取用户真实IP和防刷机制

      一. 如何获取用户IP地址 public static function getClientIp() { if (getenv('HTTP_CLIENT_IP')) { $ip = getenv( ...

  2. Nginx log日志参数详解

    $args #请求中的参数值$query_string #同 $args$arg_NAME #GET请求中NAME的值$is_args #如果请求中有参数,值为"?",否则为空字符 ...

  3. STL的相关知识

    STL简介: STL(Standard Template Library,标准模版库)以模板类和模版函数的形式为程序员提供了各种数据结构和算法的实现,程序员通过利用STL,可以在代码空间.执行时间和编 ...

  4. 时间复杂度和大O表示法

    大O表示法:称一个函数g(n)是O(f(n)),当且仅当存在常数c>0和n0>=1,对一切n>n0均有|g(n)|<=c|f(n)|成立,也称函数g(n)以f(n)为界或者称g ...

  5. RAP 接口Mock示例

    前后端分离式开发的思考 目前大部分公司都实行了前后端分离开发.然而在项目开发过程当中,经常会遇到以下几个尴尬的场景: 1.前端开发依赖于后端接口数据,需要与后端接口联调才能获得数据展示,从而拖慢了开发 ...

  6. ECharts使用心得总结

    https://blog.csdn.net/whiteosk/article/details/52684053 项目中的图表形式很多,基本可以在ECharts中找到相应实例,但UI设计图中的图表跟百度 ...

  7. myBatis:not bind 问题

    [13/07/16 03:25:44:044 CST] localhost-startStop-1 INFO pool.DruidDataSource: {dataSource-1} closed [ ...

  8. Luogu P4768 [NOI2018]归程

    题目链接 \(Click\) \(Here\) \(Kruskal\)重构树的好题.想到的话就很好写,想不到乱搞的难度反而相当高. 按照点的水位,建出来满足小根队性质的\(Kruskal\)重构树,这 ...

  9. 微信小程序:多张图片上传

    最近在写小程序的相册,需要多张图片的上传.因为小程序不支持数组的多张图片同时上传,然后根据自己的需求+借鉴网上各位大神的案例,总算搞定.分享下,不足之处,多多指教哦 页面wxml: <form ...

  10. jsr223 md5

    import java.security.MessageDigest; String content = "xxx"; MessageDigest digest = Message ...