Observer Observable

package com.util.ObservDemoTest;

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

public class ObservDemo extends Observable {
    MyView view;
    MyModel model;

    public ObservDemo() {
        view = new MyView();
        model = new MyModel();
        model.addObserver(view);
        System.out.println("1.初始化组件:\t"+"\n  Observer:"+view +"\n  Observable:"+model);
    }

    public static void main(String[] av) {
        ObservDemo me = new ObservDemo();
        me.demo();
    }

    public void demo() {
        System.out.println("2.对象发生变化。。。。");
        model.changeSomething();
    }

    /** The Observer normally maintains a view on the data */
    class MyView implements Observer {
        /** For now, we just print the fact that we got notified. */
        public void update(Observable obs, Object x) {
            System.out.print("4.");
            System.out.println("update(" + obs + "," + x + ");");
        }
    }

    /** The Observable normally maintains the data */
    class MyModel extends Observable {
        public void changeSomething() { // Notify observers of change
            System.out.println("**********************对象是否改变:  "+hasChanged()+" ****************");
            setChanged();
            System.out.println("3.对象是否改变    "+hasChanged()+"   ,调用观察者的update方法:");
            notifyObservers();
        }
    }
}

运行结果:

/********************     测试2          *********************/

package com.util.ObservDemoTest;

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

public class ObservDemo extends Observable {
	MyView view;
	MyModel model;

	public ObservDemo() {
		view = new MyView();
		model = new MyModel();
		model.addObserver(view);
		System.out.println("1.初始化组件:\t"+"\n  Observer:"+view +"\n  Observable:"+model);
	}

	public static void main(String[] av) {
		ObservDemo me = new ObservDemo();
		me.demo();
	}

	public void demo() {
		System.out.println("2.对象发生变化。。。。");
		model.changeSomething();
	}

	/** The Observer normally maintains a view on the data */
	class MyView implements Observer {
		/** For now, we just print the fact that we got notified. */
		public void update(Observable obs, Object x) {
			System.out.print("4.");
			System.out.println("update(\n  " + obs + ",\n  " + x + "\n  );");
		}
	}

	/** The Observable normally maintains the data */
	class MyModel extends Observable {
		public void changeSomething() { // Notify observers of change
			System.out.println("**********************对象是否改变:  "+hasChanged()+" ****************");
			setChanged();
			System.out.println("3.对象是否改变    "+hasChanged()+"   ,调用观察者的update方法:");
			model = new MyModel();
			notifyObservers(model);
		}
	}
}

运行结果:

/****************************************     补充                 *****************************************/

时间: 2024-08-09 14:37:26

Observer Observable的相关文章

Java观察者模式 : Observer / Observable

/** Java观察者模式的场景:一个女孩洗澡,被很多男孩偷看. 女孩洞察后,搜索坏男孩,然后继续洗澡. 三个类:Boy,Girl还有主类MainClass. */ /* 男孩 Boy.java */ import java.util.Observable; import java.util.Observer; public class Boy implements Observer{ private String name=""; public Boy(String name){ t

Observer,Observable实现观察者模式

(#)个人对于观察者的理解:观察者与发布订阅模式是非常的相似的,例如当多个威信使用者订阅了同一个主题之后,那么这个主题就是一个被观察者,而这些用户就是观察 者,当这个主题更新了新的内容以后,就要通知所有的观察者,主题更新了新的内容了 (#)TaLK IS CHEEP 场景:服务器解析DNS 1.抽象一个域名解析服务,实现java.util的Observer与Observable /** * Author: scw * Time: 16-12-28 */ public abstract class

[RxJS] Subject: an Observable and Observer hybrid

This lesson teaches you how a Subject is simply a hybrid of Observable and Observer which can act as a bridge between the source Observable and multiple observers, effectively making it possible for multiple observers to share the same Observable exe

设计模式----行为型模式之观察者模式(Observer Pattern)

下面是阅读<Head First设计模式>的笔记. 观察者模式 定义了对象之间的一对多依赖,这样一来,当一个对象改变状态时,它的所有依赖者都会收到通知并自动更新. JDK API内置机制 JDK1.0版本就已经包含了java.util.Observer和java.util.Observable,TODO. java.util.Observer是一个接口,所有使用内置机制实现观察者模式,都需要实现该接口.该接口只定义了一个方法 void update(Observable o, Object a

Rxjava2 Observable的创建详解及实例

目录 简要: 1. Create 2. Defer 3. Empty/Never/Error 4. Just 5. From 6. Repeat 7. RepeatWhen 8. RepeatUntil 9. Range 10. interval 11. Timer 小结 简要: 几种主要的需求 直接创建一个Observable(创建操作) 组合多个Observable(组合操作) 对Observable发射的数据执行变换操作(变换操作) 从Observable发射的数据中取特定的值(过滤操作)

GoF--观察者模式

观察者模式定义了对象间的一对多依赖关系,让一个或多个观察者对象观察一个主题对象.当主题对象的状态发生变化时,系统恩那个通知所有的依赖于此对象观察者对象,从而使得观察者对象能够自动更新. 在观察者模式中,被观察的对象尝尝被称为目标或主题(Subject),依赖的对象被称为观察者(Observer). Interface:Observer package edu.pri.lime._9_3_9.bean; //观察者接口,程序中所有观察者都应该实现该接口 public interface Obser

Jdk中的设计模式

转自:http://blog.csdn.net/gtuu0123/article/details/6114197 本文主要是归纳了JDK中所包含的设计模式,包括作用和其设计类图.首先来个总结,具体的某个模式可以一个一个慢慢写,希望能对研究JDK和设计模式有所帮助. 一.设计模式是什么(1)反复出现问题的解决方案(2)增强软件的灵活性(3)适应软件不断变化 二.学习JDK中设计模式的好处(1)借鉴优秀代码的设计,有助于提高代码设计能力(2)JDK的设计中体现了大多数设计模式,是学习设计模式的较好的

&lt;&lt;Head First设计模式&gt;&gt;之观察者模式学习

1.概念 定义了对象之间的一对多依赖关系,当一个对象(主题对象)的状态改变时,它的所有依赖者(观察者对象)都会收到通知并自动更新. 2.优势 观察者模式实现了主题对象与观察者对象之间的松耦合,当有新的观察者时,无需修改主题对象的代码,只需要新的观察者对象实现接口.在程序运行的过程中,可以随时注册和删除观察者而不影响主体对象. 观察者模式使主题(Subject)对象和观察者(Observer)对象都可以被轻易地复用. 3.Java中观察者模式 Java API有内置的观察者模式,java.util

retrofit+rxjava+recyclerview+下拉刷新+自动加载更多

安卓开发过程中,网络请求与下拉刷新分页列表的控件几乎可以说是必不可少的,但是每次开发一款产品都要重新开发,肯定是不可取的,那么最好是可以自己整理一个开发框架,那么以后开发,直接引入项目即可 网络框架的封装,从httpclient,到xutils,再到volley,再到okhttp,每次整合都发现多多少少的不足,目前自己觉得最成熟的一个也就是retrofit+okhttp3+rxjava的组合,rxjava不懂的推荐看大神的深入浅出rxjava,retrofit的使用自己网上搜咯 下拉刷新列表的实