Memorydoc
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
    • 前端拓展
  • 编程之道

    • 并发编程
    • 设计模式
    • 数据结构算法
    • 技术拓展
    • 技术陷阱
    • 面试宝典
  • 分布式

    • 微服务
    • 数据库
  • 项目优化实战

    • JVM 优化
    • 线程池优化
    • 模板引擎优化
    • 任务调度优化
    • 内存优化
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Memorydoc

术尚可求
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
    • 前端拓展
  • 编程之道

    • 并发编程
    • 设计模式
    • 数据结构算法
    • 技术拓展
    • 技术陷阱
    • 面试宝典
  • 分布式

    • 微服务
    • 数据库
  • 项目优化实战

    • JVM 优化
    • 线程池优化
    • 模板引擎优化
    • 任务调度优化
    • 内存优化
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 并发编程

  • 设计模式

    • 适配器模式(类兼容、适配、功能合并)
    • 装饰器模式(功能扩展、可以解决继承弊端)
    • 委派模式(分配任务,统一管理)
    • 简单工厂模式
    • 抽象工厂(解耦工厂)
    • Java自带的观察者模式(监听观察)
      • 简介
      • 案例场景
      • 继承Observable
      • 创建被观察对象
      • 添加订阅者
      • 发布通知
      • 完整代码
    • 实现观察者模式(监听观察)
    • 原型模式(克隆对象,深度复制、浅度复制)
    • 策略模式
    • 模板模式(自定义框架,具体方法用户自己实现)
    • 单例模式
    • CGlib(方法增强)
    • JDK动态代理(方法增强)
    • 自己实现静态代理
    • 处理链模式一
    • 处理链模式二
    • 处理链模式三
    • 事件模式一
    • 事件模式二
    • 回调模式
    • 建造者模式
    • 桥接模式
    • 命令模式
  • 数据结构算法

  • 技术拓展

  • 技术陷阱

  • 面试宝典

  • 微服务

  • 数据库

  • 项目优化背景

  • JVM优化

  • 技术架构
  • 设计模式
Memorydoc
2022-03-07

Java自带的观察者模式(监听观察)原创

# 简介

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

# 案例场景

模拟两种情景: 情景一:通过同步的方式 测试Java 发布通知,订阅者收到通知 情景二 :通过异步的方式 测试Java 发布通知,订阅者收到通知

注意

如果直接通过 notifyObservers 方法发布消息,并不能产生结果,要重写发布器的change方法,这样才会真正发布了

# 继承Observable

//Observable 被观察者
public static class MyObservable extends Observable {
    protected synchronized void setChanged() {
        super.setChanged();
    }//标记此 Observable对象为已改变的对象
}
1
2
3
4
5
6

# 创建被观察对象

// Observable observable = new Observable();//java自带的被观察者
MyObservable myObservable1 = new MyObservable();//这里使用自己的被观察者
MyObservable myObservable2 = new MyObservable();//这里使用自己的被观察者
1
2
3

# 添加订阅者

//添加订阅者(添加观察者)
    myObservable1.addObserver(new Observer() {
        @Override
        public void update(Observable o, Object value) {//o 代表发布器, value代表发布器发送的消息
            System.out.println(Thread.currentThread().getName() + value);
        }
    });

//添加订阅者(添加观察者)
myObservable2.addObserver(new Observer() {
    @Override
    public void update(Observable o, Object value) {//o 代表发布器, value代表发布器发送的消息
        System.out.println(Thread.currentThread().getName() + value);
    }
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

# 发布通知

myObservable1.setChanged();
myObservable2.setChanged();
myObservable2.notifyObservers("我醒了");
//发布通知,订阅者被动感知(推模式)
//myObservable.notifyObservers("hello world");
MyThread myThread = new MyThread(myObservable1);
new Thread(myThread).start();
//myObservable1.notifyObservers();
1
2
3
4
5
6
7
8

# 完整代码

/**
 * @version 1.0
 * @program: springTest
 * @description: Java自带的观察者模式
 * 如果直接通过  notifyObservers 方法发布消息,并不能产生结果,要重写发布器的change方法,这样才会真正发布了
 * @author: Kevin
 * @create: 2019-06-27 23:10
 **/
public class JdkObserver {

    public static void main(String[] args) {
        // Observable observable = new Observable();//java自带的被观察者
        MyObservable myObservable1 = new MyObservable();//这里使用自己的被观察者
        MyObservable myObservable2 = new MyObservable();//这里使用自己的被观察者

        //添加订阅者(添加观察者)
        myObservable1.addObserver(new Observer() {
            @Override
            public void update(Observable o, Object value) {//o 代表发布器, value代表发布器发送的消息
                System.out.println(Thread.currentThread().getName() + value);
            }
        });

        //添加订阅者(添加观察者)
        myObservable2.addObserver(new Observer() {
            @Override
            public void update(Observable o, Object value) {//o 代表发布器, value代表发布器发送的消息
                System.out.println(Thread.currentThread().getName() + value);
            }
        });//添加订阅者


        myObservable1.setChanged();
        myObservable2.setChanged();
        myObservable2.notifyObservers("我醒了");
        //发布通知,订阅者被动感知(推模式)
        //myObservable.notifyObservers("hello world");
        MyThread myThread = new MyThread(myObservable1);
        new Thread(myThread).start();
        //myObservable1.notifyObservers();

    }

    public static class MyThread implements Runnable {
        private MyObservable myObservable;

        public MyThread(MyObservable myObservable) {
            this.myObservable = myObservable;
        }

        @Override
        public void run() {
            try {
                System.out.println(Thread.currentThread().getName() + "正在睡觉");
                Thread.sleep(1000);
                System.out.println("睡醒了");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            myObservable.notifyObservers("我醒了");
        }
    }

    //Observable 被观察者
    public static class MyObservable extends Observable {
        protected synchronized void setChanged() {
            super.setChanged();
        }//标记此 Observable对象为已改变的对象
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70

# 测试结果

main我是订阅者二,我醒了
正在睡觉
睡醒了
Thread-0我醒了
1
2
3
4
编辑 (opens new window)
上次更新: 2022/03/13, 21:24:24
抽象工厂(解耦工厂)
实现观察者模式(监听观察)

← 抽象工厂(解耦工厂) 实现观察者模式(监听观察)→

最近更新
01
命令模式 原创
05-03
02
桥接模式 原创
05-02
03
优雅写代码三 原创
04-29
更多文章>
Theme by Memorydoc | Copyright © 2021-2022 Memorydoc | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式