Java设计模式 _行为型模式_观察者模式

一、观察者模式

1、观察者模式

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

2、实现思路

(1)、定义被观察者的行为(包含业务数据,观察者列表,添加观察者的方法,通知观察者的方法等)。定义规范后,在编写实现类。本例直接编写了实现类。

(2)、编写观察者的行为和实现类。(行为:将自身添加到主题的属性中,复写接收数据的方法)

二、代码示例

1、示例场景

多个观察者观察一个主题,主题发生改变时,促发各个观察者自身的业务方法。
2、代码示例

java 复制代码
// 1、定义主题(被观察者)
import lombok.Data;
import java.util.ArrayList;
import java.util.List;
@Data
public class Subject {
    private String data;
    List<Observer> observerList;   // 观察者列表

    public Subject() {
        observerList = new ArrayList<>();
    }

    public void setData(String data) {   // 发布消息,通知所有观察者
        this.data = data;
        System.out.println("发布了消息:"+this.data);
        notifyAllObser();
    }

    public void addObserver(Observer observer) {  // 添加观察者
        observerList.add(observer);
    }

    public void notifyAllObser() {   // 通知观察者
        for (Observer observer : observerList) {
            observer.getSubData();
        }
    }
}
// 2、定义观察者规范
public abstract class Observer {
    public Subject subject;
    public abstract void getSubData();
}
// 3.1、编写观察者实现类,记者类
public class Reporter extends Observer {
    public Reporter(Subject subject) {
        this.subject = subject;
        this.subject.addObserver(this);
    }

    @Override
    public void getSubData() {
        System.out.println("记者观察到消息:" + subject.getData());
    }
}
// 3.2、编写观察者实现类,厨师类
public class Cooker extends Observer {
    public Cooker(Subject subject) {
        this.subject = subject;
        this.subject.addObserver(this);
    }

    @Override
    public void getSubData() {
        System.out.println("厨师观察到消息:" + subject.getData());
    }
}
// 4、测试
public static void main(String[] args) {
        Subject subject = new Subject();
        Observer observer1 = new Reporter(subject);
        Observer observer2 = new Cooker(subject);

        subject.setData("1111");
        System.out.println("************");
        subject.setData("2222");
    }

由上图可看到,当主题发布消息后,该主题对象的观察者集合中的每一个人都可以接收到消息。

总结:

观察者模式往往用于一对多的场景,主要套路为你中有我,我中有你。所以代码上要把观察者内置到被观察者的属性中(列表),被观察者也要内置到观察者中,彼此定义了对方的属性,之后封装数据可以是构造方法实现,也可以是自定义方法等。形成这种关系后,当被观察者发生改变时,就可以把被观察者的业务消息通知到内置的观察者列表中,通常是直接调用观察者的方法实现。

学海无涯苦作舟!!!

相关推荐
wang09076 小时前
自己动手写一个spring之IOC_2
java·后端·spring
来杯@Java6 小时前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis
不知名的老吴7 小时前
线程的生命周期之线程“插队“
java·开发语言·python
ANnianStriver7 小时前
PetLumina-02-后端开发与前后端联调
java·ai·sa-token
杨了个杨89828 小时前
Keepalived + Nginx + HAProxy 高可用架构部署实战案例
java·nginx·架构
马士兵教育10 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
snow@li11 小时前
Java:理解 Gradle / 后端项目的管家 / 打包SpringBoot 应用 / 完成编译、下载依赖、运行测试、打包 JAR/WAR / 速查表
java
云烟成雨TD11 小时前
Spring AI 1.x 系列【57】动态工具发现:Tool Search Tool
java·人工智能·spring
zfoo-framework11 小时前
[修改代码使用]codex官方app中使用中转(不需要cc-switch) 1.config.toml 2.sk方式登录
java