此博客用于个人学习,来源于ssm框架的书籍,对知识点进行一个整理。
2.3 观察者(Observer)模式
观察者模式又称为发布订阅模式,是对象的行为模式。它定义了一种一对多的依赖关系,即——多个观察者对象同时监视着被观察者的状态,当被观察者的状态发生变化的时候,会通知所有观察者,并让其自动更新自己。
2.3.1 概述
举一个生活中的例子,比如一个商家有一些产品,需要跟一些电商合作,每当有新产品的时候,就会把这批产品推送到电商,现在只有和淘宝,京东合作,于是就有下面的伪代码:
if(产品库有新产品){
推送产品到淘宝;
推送产品到京东;
}
而这个时候,公司又和其他电商合作,比如,国美,苏宁,当当,唯品会等,就需要对这段伪代码进行一定程度的修改:
if(产品库有新产品){
推送产品到淘宝;
推送产品到京东;
推送产品到国美;
推送产品到苏宁;
推送产品到当当;
推送产品到唯品会;
}
如果以后和其他电商合作,那么还要继续在 if 语句中添加更多的逻辑。这样的话,存在如下的缺点:
- 如果有多达百家电商进行合作,if 语句的逻辑会变得十分冗长和复杂,不利于维护,同时造成扩展困难。
- 代码耦合度增加。如果发给淘宝的代码出现异常,会导致下面的无法进行。
- 会造成不同团队责任不清的情况。
而观察者模式更易于进行扩展,责任也更加清晰。首先,把每一个电商接口看成一个观察者,每一个观察者都能观察到产品列表(被监听对象)。当公司发布新产品时,就会发送到这个产品列表上,于是产品列表(被监听对象)就发生了变化,就会触发这个电商接口(监听者)发送新产品到对应的合作电商那里。

这样的好处在于,程序不再出现 if 语句,观察者会根据被观察对象的变化而做出相应的行为,每个电商接口只需要维护自己的逻辑,而无须耦合在一起,同时也避免了责任不明确的情况出现。
2.3.2实例
被观察的产品列表代码如下:
public class productList extends Observable {
//产品列表
private List<String> productList = null;
//类唯一实例
private static productList instance;
//构建方法私有化
private productList(){};
/**
* 取得唯一实例
* @return
*/
public static productList getInstance(){
if(instance == null){
instance = new productList();
instance.productList = new ArrayList<String>();
}
return instance;
}
/**
* 增加观察者
* @param observer
*/
public void addProductListObserver(Observer observer){
this.addObserver(observer);
}
/**
* 新增产品
* @param newProduct
*/
public void addProduct(String newProduct){
productList.add(newProduct);
System.out.println("产品列表又新增了产品:"+newProduct);
//设置观察对象发生了变化
this.setChanged();
//通知观察者,并传递新产品
this.notifyObservers(newProduct);
}
}
这个类的一些基本内容和主要方法如下:
- 构建方法私有化,避免通过 new 的方式创建对象,而是通过 getInstance 方法获得产品列表单例,这里使用的就是单例模式。
- addProductListObserver 可以增加一个电商接口(观察者)。
- addProduct 为核心的方法,在产品列表上增加了一个新的产品,然后调用 setChange 方法。这个方法用于告知观察者当前被观察者发生了变化,如果没有,则无法触发其行为。最后通过 notifyObservers 告知观察者,让他们发生相应的动作,并将新产品作为参数传入观察者中。
编写观察者对象,以淘宝和京东为例去实现他们的电商接口。
public class JingDongObserver implements Observer {
@Override
public void update(Observable o, Object product) {
String newProduct = (String) product;
System.out.println("发送新产品:"+newProduct+"到京东商城");
}
}
public class TaoBaoObserver implements Observer {
@Override
public void update(Observable o, Object product) {
String newProduct = (String) product;
System.out.println("发送新产品:"+newProduct+"到淘宝商城");
}
}
进行测试:
public static void main(String[] args) {
productList observer = productList.getInstance();
TaoBaoObserver taoBaoObserver = new TaoBaoObserver();
JingDongObserver jingDongObserver = new JingDongObserver();
observer.addObserver(taoBaoObserver);
observer.addObserver(jingDongObserver);
observer.addProduct("新增产品1");
}
运行结果为:
产品列表又新增了产品:新增产品1
发送新产品:新增产品1到京东商城
发送新产品:新增产品1到淘宝商城
下面两行代码是将被观察者与观察者进行注册,从而达到观察的效果。
observer.addObserver(taoBaoObserver);
observer.addObserver(jingDongObserver);
本文深入讲解了观察者模式,一种对象的行为模式,定义了一对多的依赖关系,使得多个观察者对象能同时监视被观察者状态。当状态改变时,所有观察者自动更新。文章通过电商合作案例,展示了如何使用观察者模式简化代码,提高扩展性和清晰度。

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



