来自《headfirst设计模式》
观察者模式定义了对象之间的一对多的依赖关系,这样一来,当一个对象改变状态的时候,它的所有依赖者(观察者)都会收到通知并自动更新。
观察者模式提供了一种对象设计,让主题和观察者之间松耦合。主题只知道观察者实现了某个接口,不知道具体的观察者是谁。因为主题唯一依赖的东西就是Obeserver接口的对象列表。有新类型的观察者出现时,主题的代码不需要修改,它仅仅需要发送通知给所有实现了观察者接口的对象。
下面设计一个气象观测板,它可以受到天气的变化,并显示出来
1.首先设计接口,观察者、主题接口
/*
* 观察者接口,所有观察者实现改接口
*
* */
public interface Observer {
public abstract void update(float temp,float humidity,float pressure); //将数据更新
}
/*
* 主题接口,主题实现该接口
* 可以增加观察者、移除观察者、通知所有观察者
*/
public interface Subject {
public void registerObserver(Observer o);
public void removeObserver(Observer o);
public void notifyObservers();
}
/*
* 显示面板
* 输出当前的天气状况
*/
public interface DisplayElement {
public void display();
}
2.实现接口
import java.util.ArrayList;
public class WeatherData implements Subject{
private ArrayList<Observer> observers; //用来存储所有的观察者
private float temperature; //温度
private float humidity; //湿度
private float pressure; //气压
public WeatherData(){
observers=new ArrayList<Observer>();
}
@Override
public void registerObserver(Observer o) { //添加观察者
// TODO Auto-generated method stub
observers.add(o);
}
@Override
public void removeObserver(Observer o) { //移除观察者
// TODO Auto-generated method stub
int i=observers.indexOf(o);
if(i>=0){
observers.remove(i);
}
}
@Override
public void notifyObservers() { //通知所有观察者
// TODO Auto-generated method stub
if(observers.size()==0){
System.out.println("Sorry i have no observer !!!!!!!");
}
for(int i=0;i<observers.size();i++){
Observer observer=observers.get(i);
observer.update(temperature, humidity, pressure);
}
}
public void measurementsChanged(){
notifyObservers();
}
public void setMeasurements(float temperature, float humidity, float pressure) { //执行此方法即通知观察者
this.temperature = temperature;
this.humidity = humidity;
this.pressure = pressure;
measurementsChanged();
}
}
public class CurrentConditionsDisplay implements Observer,DisplayElement{
private float temperature;
private float humidity;
private Subject weatherData;
public CurrentConditionsDisplay(Subject weatherData) {
super();
this.weatherData = weatherData;
//weatherData.registerObserver(this);
}
@Override
public void display() { //显示
// TODO Auto-generated method stub
System.out.println("current conditions is : temperature--->"+temperature+" , humidity----> "+humidity);
}
@Override
public void update(float temp, float humidity, float pressure) {
// TODO Auto-generated method stub
this.temperature=temp;
this.humidity=humidity;
display();
}
}
3.主函数
public class WeatherStation {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
WeatherData weatherData=new WeatherData();
CurrentConditionsDisplay currentConditionsDisplay=new CurrentConditionsDisplay(weatherData);
weatherData.registerObserver(currentConditionsDisplay); //增加观察者
//主题发生了变化
weatherData.setMeasurements(80, 65, 30.4f);
weatherData.setMeasurements(82, 70, 29.2f);
weatherData.setMeasurements(78, 90, 29.2f);
}
}
4.输出结果
current conditions is : temperature--->80.0 , humidity----> 65.0
current conditions is : temperature--->82.0 , humidity----> 70.0
current conditions is : temperature--->78.0 , humidity----> 90.0