zoukankan      html  css  js  c++  java
  • php模式设计之 观察者模式

    • 观察者模式

    观察者设计模式能够更便利创建和查看目标对象状态的对象,并且提供和核心对象非耦合的置顶功能性。观察者设计模式非常常用,在一般复杂的WEB系统中,观察者模式可以帮你减轻代码设计的压力,降低代码耦合。

    • 场景设计
    1. 设计一个订单类
    2. 订单创建完成后,会做各种动作,比如发送EMAIL,或者改变订单状态等等。
    3. 原始的方法,是将这些操作都写在create函数里面
    4. 但是随着订单创建类的越来越庞大,这样的操作已经无法满足需求和快速变动
    5. 这个时候,观察者模式出现了。
    • 代码设计:
          <?php  
          //观察者设计模式能够更便利创建和查看目标对象状态的对象,并且提供和核心对象非耦合的置顶功能性。  
          //观察者设计模式非常常用,在一般复杂的WEB系统中,观察者模式可以帮你减轻代码设计的压力,降低代码耦合。  
          //以一个购物流程为例子  
          class order {  
            
              protected $observers = array(); // 存放观察容器  
                
              //观察者新增  
              public function addObServer($type, $observer) {  
                  $this->observers[$type][] = $observer;  
              }  
                
              //运行观察者  
              public function obServer($type) {  
                  if (isset($this->observers[$type])) {  
                      foreach ($this->observers[$type] as $obser) {  
                          $a = new $obser;  
                          $a->update($this); //公用方法  
                      }  
                  }  
              }  
                
              //下单购买流程  
              public function create() {  
                  echo '购买成功';  
                  $this->obServer('buy'); // buy动作  
              }  
          }  
          class orderEmail {  
              public static function update($order) {  
                  echo '发送购买成功一个邮件';  
              }  
          }  
          class orderStatus {  
              public static function update($order) {  
                  echo '改变订单状态';  
              }  
          }  
          $ob = new order;  
          $ob->addObServer('buy', 'orderEmail');  
          $ob->addObServer('buy', 'orderStatus');  
          $ob->create();  

      原文链接:http://blog.csdn.net/initphp/article/details/7708006

  • 相关阅读:
    delphi 线程的使用
    mysql + unidac 使用事务例子
    unidac 执行Execute后取得受影响行数。
    关于UNIDAC连接SQLITE3的心得笔记
    FIREDAC的心得
    unidac连接ORACLE免装客户端驱动
    delphi 2010安装unidac
    DELPHI中使用UNIDAC连接ORACLE数据库
    Struts2思维导图
    面试经验And总结
  • 原文地址:https://www.cnblogs.com/mr-amazing/p/4789626.html
Copyright © 2011-2022 走看看