Java 回调函数 与 观察者模式
        【摘要】 
                    
                        
                    
                    观察者模式(有时又被称为发布(publish )-订阅(Subscribe)模式、模型-视图(View)模式、源-收听者(Listener)模式或从属者模式)是软件设计模式的一种。在此种模式中,一个目标物...
    
    
    
    观察者模式(有时又被称为发布(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();
    }
}
  
 - 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
- 71
- 72
- 73
- 74
- 75
- 76
- 77
输出结果:
countObservers = 2
ConcreteObserverB update
ConcreteObserverA update
callback onCall
  
 - 1
- 2
- 3
- 4
从上面代码可以看出:回调函数应该属于观察者模式的一种,目的是为了替代轮循机制,将组件之间的耦合性降低。观察者模式里面目标类维护了所有观察者的引用,而回调里面只是维护了一个引用。
文章来源: blog.csdn.net,作者:福州-司马懿,版权归原作者所有,如需转载,请联系作者。
原文链接:blog.csdn.net/chy555chy/article/details/52777989
        【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
            cloudbbs@huaweicloud.com
        
        
        
        
        
        
        - 点赞
- 收藏
- 关注作者
 
             
           
评论(0)