观察者模式应用场景实例

<?php

/**

 * 观察者模式应用场景实例

 *

 * 免责声明:本文只是以哈票网举例,示例中并未涉及哈票网任何业务代码,全部原创,如有雷同,纯属巧合。

 *

 * 场景描述:

 * 哈票以购票为核心业务(此模式不限于该业务),但围绕购票会产生不同的其他逻辑,如:

 * 1、购票后记录文本日志

 * 2、购票后记录数据库日志

 * 3、购票后发送短信

 * 4、购票送抵扣卷、兑换卷、积分

 * 5、其他各类活动等

 *

 * 传统解决方案:

 * 在购票逻辑等类内部增加相关代码,完成各种逻辑。

 *

 * 存在问题:

 * 1、一旦某个业务逻辑发生改变,如购票业务中增加其他业务逻辑,需要修改购票核心文件、甚至购票流程。

 * 2、日积月累后,文件冗长,导致后续维护困难。

 *

 * 存在问题原因主要是程序的"紧密耦合",使用观察模式将目前的业务逻辑优化成"松耦合",达到易维护、易修改的目的,

 * 同时也符合面向接口编程的思想。

 *

 * 观察者模式典型实现方式:

 * 1、定义2个接口:观察者(通知)接口、被观察者(主题)接口

 * 2、定义2个类,观察者对象实现观察者接口、主题类实现被观者接口

 * 3、主题类注册自己需要通知的观察者

 * 4、主题类某个业务逻辑发生时通知观察者对象,每个观察者执行自己的业务逻辑。

 *

 * 示例:如以下代码

 *

 */

#===================定义观察者、被观察者接口============

/**

 *

 * 观察者接口(通知接口)

 *

 */

interface ITicketObserver //观察者接口

{

    function onBuyTicketOver($sender, $args); //得到通知后调用的方法

}

 

/**

 *

 * 主题接口

 *

 */

interface ITicketObservable //被观察对象接口

{

    function addObserver($observer); //提供注册观察者方法

}

#====================主题类实现========================

/**

 *

 * 主题类(购票)

 *

 */

class HipiaoBuy implements ITicketObservable { //实现主题接口(被观察者)

    private $_observers = array (); //通知数组(观察者)

   

 

    public function buyTicket($ticket) //购票核心类,处理购票流程

{

       // TODO 购票逻辑

      

 

       //循环通知,调用其onBuyTicketOver实现不同业务逻辑

       foreach ( $this->_observers as $obs )

           $obs->onBuyTicketOver ( $this, $ticket ); //$this 可用来获取主题类句柄,在通知中使用

    }

   

    //添加通知

    public function addObserver($observer) //添加N个通知

{

       $this->_observers [] = $observer;

    }

}

 

#=========================定义多个通知====================

//短信日志通知

class HipiaoMSM implements ITicketObserver {

    public function onBuyTicketOver($sender, $ticket) {

       echo (date ( 'Y-m-d H:i:s' ) . " 短信日志记录:购票成功:$ticket<br>");

    }

}

//文本日志通知

class HipiaoTxt implements ITicketObserver {

    public function onBuyTicketOver($sender, $ticket) {

       echo (date ( 'Y-m-d H:i:s' ) . " 文本日志记录:购票成功:$ticket<br>");

    }

}

//抵扣卷赠送通知

class HipiaoDiKou implements ITicketObserver {

    public function onBuyTicketOver($sender, $ticket) {

       echo (date ( 'Y-m-d H:i:s' ) . " 赠送抵扣卷:购票成功:$ticket 赠送10元抵扣卷1张。<br>");

    }

}

#============================用户购票====================

$buy = new HipiaoBuy ();

$buy->addObserver ( new HipiaoMSM () ); //根据不同业务逻辑加入各种通知

$buy->addObserver ( new HipiaoTxt () );

$buy->addObserver ( new HipiaoDiKou () );

//购票

$buy->buyTicket ( "一排一号" );

?>

 

版权所有:Robot_G(swengineer)  欢迎转载 http://blog.csdn.net/swengineer/archive/2011/03/22/6268244.aspx

  • 15
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
观察者模式(Observer Pattern)是一种常用的设计模式,它用于对象间的一对多依赖关系的处理,当一个对象的状态发生改变时,所有依赖它的对象都会得到通知并自动更新。 在JavaScript中,观察者模式通常用于DOM事件监听、异步回调、数据绑定等场景。下面是一个简单的实例,使用观察者模式实现一个发布-订阅模式的事件处理器。 ```javascript // 事件处理器 class EventHandler { constructor() { this.handlers = {}; } // 订阅事件 subscribe(eventName, handler) { if (!this.handlers[eventName]) { this.handlers[eventName] = []; } this.handlers[eventName].push(handler); } // 取消订阅 unsubscribe(eventName, handler) { if (!this.handlers[eventName]) { return; } const index = this.handlers[eventName].indexOf(handler); if (index !== -1) { this.handlers[eventName].splice(index, 1); } } // 发布事件 publish(eventName, ...args) { if (!this.handlers[eventName]) { return; } this.handlers[eventName].forEach(handler => handler(...args)); } } // 使用示例 const eventHandler = new EventHandler(); // 订阅事件 eventHandler.subscribe('click', () => console.log('click event fired')); eventHandler.subscribe('change', (value) => console.log(`value changed to ${value}`)); // 发布事件 eventHandler.publish('click'); // 输出: "click event fired" eventHandler.publish('change', 10); // 输出: "value changed to 10" // 取消订阅 const handler = () => console.log('test'); eventHandler.subscribe('test', handler); eventHandler.unsubscribe('test', handler); ``` 在上面的代码中,我们创建了一个 EventHandler 类,它包含了三个方法:subscribe、unsubscribe 和 publish。它们分别用于订阅事件、取消订阅事件和发布事件。在使用时,我们可以通过调用 subscribe 方法来订阅事件,通过 publish 方法来发布事件,通过 unsubscribe 方法来取消订阅事件。当发布一个事件时,所有订阅该事件的处理器都会被调用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值