前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >观察者模式观察者模式

观察者模式观察者模式

作者头像
OPice
发布2021-09-07 17:03:59
8480
发布2021-09-07 17:03:59
举报
文章被收录于专栏:D·技术专栏

介绍

观察者属于行为模式,当一个对象改变时,会通知订阅者做相应的处理。 是一种低耦合的方式,观察者和被观察者者之间不互相依赖。 缺点或者说需要注意的点:1、如果观察者很多,要通知所有的观察者需要很多时间 2、观察者之间互相循环调用,会导致系统崩溃。

Demo

1、定义一个被观察者

代码语言:javascript
复制
public class Subject {
    //监控的状态
    private Integer state;

    //维护所有观察者的列表
    private List<Observer> observerList = new ArrayList<>();

    public Integer getState() {
        return state;
    }

    //状态被改变 通知所有的观察者
    public void setState(Integer state) {
        this.state = state;
        notifyAllObserver();
    }

    public void attach(Observer observer) {
        observerList.add(observer);
    }

    //通知
    public void notifyAllObserver() {
        observerList.forEach(Observer::update);
    }
}

2、定义多个观察者

代码语言:javascript
复制
/**
 * 二进制观察者
 */
public class BinaryObserver extends Observer {

    public BinaryObserver(Subject subject) {
        this.subject = subject;
        subject.attach(this);
    }

    @Override
    void update() {
        System.out.println("BinaryObserver :"+Integer.toBinaryString(subject.getState()));
    }
}
代码语言:javascript
复制
/**
 * 八进制观察者
 */
public class OctalObserver extends Observer {
    public OctalObserver(Subject subject) {
        this.subject = subject;
        subject.attach(this);
    }

    @Override
    void update() {
        System.out.println("OctalObserver :" + Integer.toOctalString(subject.getState()));
    }
}
代码语言:javascript
复制
/**
 * 十六进制观察者
 */
public class HexObserver extends Observer {
    public HexObserver(Subject subject) {
        this.subject = subject;
        subject.attach(this);
    }

    @Override
    void update() {
        System.out.println("HexObserver :" + Integer.toHexString(subject.getState()));
    }
}

3、执行

代码语言:javascript
复制
public class ObserverPatternTest {
    public static void main(String[] args) {
        Subject subject = new Subject();

        new BinaryObserver(subject);
        new HexObserver(subject);
        new OctalObserver(subject);

        subject.setState(10);
        subject.setState(15);
    }
}

4、执行结果

image.png

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 介绍
  • Demo
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档