Java 回调函数 与 观察者模式

观察者模式(有时又被称为发布(publish )-订阅(Subscribe)模式、模型-视图(View)模式、源-收听者(Listener)模式或从属者模式)是软件设计模式的一种。在此种模式中,一个目标物件管理所有相依于它的观察者物件,并且在它本身的状态改变时主动发出通知。这通常透过呼叫各观察者所提供的方法来实现。此种模式通常被用来实现事件处理系统。

什么时候使用观察者模式:

  • 当一个抽象模型有两个方面, 其中一个方面依赖于另一方面。将这二者封装在独立的对象中以使它们可以各自独立地改变和复用。
  • 当对一个对象的改变需要同时改变其它对象, 而不知道具体有多少对象有待改变。
  • 当一个对象必须通知其它对象,而它又不能假定其它对象是谁。换言之, 你不希望这些对象是紧密耦合的。

其实观察者模式同前面讲过的桥梁、策略有着共同的使用环境:将变化独立封装起来,以达到最大的重用和解耦。观察者与后两者不同的地方在于,观察者模式中的目标和观察者的变化不是独立的,而是有着某些联系。

在Java中通过Observable类和Observer接口实现了观察者模式。一个Observer对象监视着一个Observable对象的变化,当Observable对象发生变化时,Observer得到通知,就可以进行相应的工作。

package com.demo.test;

import java.util.Observable;
import java.util.Observer;

//观察者模式里面目标类维护了所有观察者的引用,而回调里面只是维护了一个引用
public class ObserverCallbackDemo {

    // 观察者A
    static class ConcreteObserverA implements Observer {

        @Override
        public void update(Observable o, Object arg) {
            System.out.println("ConcreteObserverA update");
        }

    }

    // 观察者B
    static class ConcreteObserverB implements Observer {

        @Override
        public void update(Observable o, Object arg) {
            System.out.println("ConcreteObserverB update");
        }

    }

    // 被观察对象
    static class ConcreteObservable extends Observable {
        public void changeValue() {
            //protected方法只能在子类被调用
            setChanged();
            notifyObservers();
        }
    }

    // 回调函数接口
    interface ICallback {
        public void onCall();
    }

    // 回调类
    static class CallbackDemo {
        private ICallback callback;

        public void setListener(ICallback callback) {
            this.callback = callback;
        }

        public void call() {
            callback.onCall();
        }
    }

    public static void main(String[] args) {
        // 观察者
        ConcreteObserverA observerA = new ConcreteObserverA();
        ConcreteObserverB observerB = new ConcreteObserverB();
        ConcreteObservable observable = new ConcreteObservable();
        observable.addObserver(observerA);
        observable.addObserver(observerB);
        System.out.println("countObservers = " + observable.countObservers());
        observable.changeValue();

        // 回调函数
        CallbackDemo callbackDemo = new CallbackDemo();
        callbackDemo.setListener(new ICallback() {

            @Override
            public void onCall() {
                System.out.println("callback onCall");
            }
        });
        callbackDemo.call();
    }
}

输出结果:

countObservers = 2
ConcreteObserverB update
ConcreteObserverA update
callback onCall

从上面代码可以看出:回调函数应该属于观察者模式的一种,目的是为了替代轮循机制,将组件之间的耦合性降低。观察者模式里面目标类维护了所有观察者的引用,而回调里面只是维护了一个引用。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值