如果你现在接了一个需求: 需要搭建一个天气预报站,用于接收实时天气信息:温度,可见度,气压。然后又许多的显示器,根据天气预报站数据的变化,来显示不同的信息。如何实现改需求?
上面这个问题,就引出了观察者模式。
观察者模式
什么是观察者模式: 观察者模式是一个1对多的关系,主要组成又Subject,Observer。Subject就是天气预报站,而Observer就是显示器。Observer通过订阅Subject,来获得Subject改变的通知。
使用观察者模式来实现需求
- 接口
//subject主体,被订阅的对象,这里表示天气预报站
public interface Subject {
void register(Observer o);//订阅方法
void remove(Observer o);//取消订阅
void notifyObservers();
}
//Observer观察者,通过订阅Subject来获取相关信息
public interface Observer {
void update(float temperature, float humidity, float pressure);
}
public interface DisplayElement {
void display();
}
- 具体的实现
//天气预报站,实现Subject接口
public class WeatherData implements Subject {
private ArrayList<Observer> observers;//用于存储订阅的Observer,我们不关心谁订阅了这个Subject,我们只向订阅者提供相关信息。
private float temperature;
private float humidity;
private float pressure;
@Override
public void register(Observer o) {
if(observers == null) {
observers = new ArrayList<>();
}
observers.add(o);
}
@Override
public void remove(Observer o) {
int i = observers.indexOf(o);
if(i > 0) {
observers.remove(i);
}
}
//通知所有的Observer,调用Observer.update(),来变更订阅者的信息。
@Override
public void notifyObservers() {
for(Observer o: observers) {
o.update(temperature, humidity, pressure);
}
}
public void measurementsChange() {
notifyObservers();
}
//改变信息,同时调用通知方法
public void setMeasurements(float temperature, float humidity, float pressure) {
this.temperature = temperature;
this.humidity = humidity;
this.pressure = pressure;
measurementsChange();
}
}
//订阅者,这里就是显示器
public class CurrentConditionsDisplay implements Observer, DisplayElement {
private float temperature;
private float humidity;
private float pressure;
//这个很有必要,因为以后可能需要remove()
private Subject weatherData;
//通过构造函数来设置Subject,也就是说设置订阅的对象。
public CurrentConditionsDisplay(Subject weatherData) {
this.weatherData = weatherData;
weatherData.register(this);
}
@Override
public void display() {
System.out.println("temperature: " + temperature + " humidity: " + humidity + " pressure: " + pressure);
}
//update,这个方法被Subject调用
@Override
public void update(float temperature, float humidity, float pressure) {
this.temperature = temperature;
this.humidity = humidity;
this.pressure = pressure;
display();
}
public static void main(String[] args) {
WeatherData weatherData = new WeatherData();
CurrentConditionsDisplay currentConditionsDisplay = new CurrentConditionsDisplay(weatherData);
currentConditionsDisplay.display();
weatherData.setMeasurements(1.0f, 2.0f, 3.0f);
weatherData.setMeasurements(1.0f, 4.0f, 3.0f);
}
}
436

被折叠的 条评论
为什么被折叠?



