zoukankan      html  css  js  c++  java
  • 设计模式之责任链模式(php实现)


    github地址:https://github.com/ZQCard/design_pattern

    /**
     * 责任链模式(Chain of Responsibility Pattern)为请求创建了一个接收者对象的链。
     * 这种模式给予请求的类型,对请求的发送者和接收者进行解耦。这种类型的设计模式属于行为型模式。
     * 在这种模式中,通常每个接收者都包含对另一个接收者的引用。如果一个对象不能处理该请求,
     * 那么它会把相同的请求传给下一个接收者,依此类推。
     * 避免请求发送者与接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连接成一条链,并且沿着这条链传递请求,直到有对象处理它为止。
     * 优点:
     * 1、降低耦合度。它将请求的发送者和接收者解耦。
     * 2、简化了对象。使得对象不需要知道链的结构。
     * 3、增强给对象指派职责的灵活性。通过改变链内的成员或者调动它们的次序,允许动态地新增或者删除责任。
     * 4、增加新的请求处理类很方便。
     * 缺点:
     * 1、不能保证请求一定被接收。
     * 2、系统性能将受到一定影响,而且在进行代码调试时不太方便,可能会造成循环调用。
     * 3、可能不容易观察运行时的特征,有碍于除错。
     * 例子以日志错误级别记录为例
     */

    (1)AbstractLogger.class.php(抽象日志父类)

    <?php
    
    namespace ChainOfResponsibility;
    
    abstract class AbstractLogger
    {
        public static $INFO = 1;
        public static $DEBUG = 2;
        public static $ERROR = 3;
    
        protected $level;
    
        protected $nextLogger;
    
        public function setNextLogger(AbstractLogger $nextLogger)
        {
            $this->nextLogger = $nextLogger;
        }
    
        public function logMessage($level, $message)
        {
            if ($this->level <= $level){
                $this->write($message);
            }
    
            if ($this->nextLogger != null){
                $this->nextLogger->logMessage($level, $message);
            }
        }
    
        abstract protected function write($message);
    }

    (2)ErrorLogger.class.php(错误级别日志处理类)

    <?php
    
    namespace ChainOfResponsibility;
    
    class ErrorLogger extends AbstractLogger
    {
    
        public function __construct($level)
        {
            $this->level = $level;
        }
        
        protected function write($message)
        {
            echo "Error Error::Logger: " . $message;
            echo '<br/>';
        }
    }

    (3)DebugLogger.class.php(调试级别处理类)

    <?php
    
    namespace ChainOfResponsibility;
    
    class DebugLogger extends AbstractLogger
    {
    
        public function __construct($level)
        {
            $this->level = $level;
        }
        
        protected function write($message)
        {
            echo "Error File::Logger: " . $message;
            echo '<br/>';
        }
    }

    (4)ConsoleLogger.class.php(消息级别处理类)

    <?php
    
    namespace ChainOfResponsibility;
    
    class ConsoleLogger extends AbstractLogger
    {
    
        public function __construct($level)
        {
            $this->level = $level;
        }
        
        protected function write($message)
        {
            echo "Error Console::Logger: " . $message;
            echo '<br/>';
        }
    }

    (5)chainOfResponsibility.php(客户端)

    <?php
    
    /**
     * 责任链模式(Chain of Responsibility Pattern)为请求创建了一个接收者对象的链。
     * 这种模式给予请求的类型,对请求的发送者和接收者进行解耦。这种类型的设计模式属于行为型模式。
     * 在这种模式中,通常每个接收者都包含对另一个接收者的引用。如果一个对象不能处理该请求,
     * 那么它会把相同的请求传给下一个接收者,依此类推。
     * 避免请求发送者与接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连接成一条链,并且沿着这条链传递请求,直到有对象处理它为止。
     * 优点:
     * 1、降低耦合度。它将请求的发送者和接收者解耦。
     * 2、简化了对象。使得对象不需要知道链的结构。
     * 3、增强给对象指派职责的灵活性。通过改变链内的成员或者调动它们的次序,允许动态地新增或者删除责任。
     * 4、增加新的请求处理类很方便。
     * 缺点:
     * 1、不能保证请求一定被接收。
     * 2、系统性能将受到一定影响,而且在进行代码调试时不太方便,可能会造成循环调用。
     * 3、可能不容易观察运行时的特征,有碍于除错。
     *
     */
    
    spl_autoload_register(function ($className){
        $className = str_replace('\','/',$className);
        include $className.".class.php";
    });
    
    use ChainOfResponsibilityErrorLogger;
    use ChainOfResponsibilityAbstractLogger;
    
    // 生成责任链
    function getChainOfLoggers(){ $errorLogger = new ErrorLogger(AbstractLogger::$ERROR); $debugLogger = new ErrorLogger(AbstractLogger::$DEBUG); $consoleLogger = new ErrorLogger(AbstractLogger::$INFO); $errorLogger->setNextLogger($debugLogger); $debugLogger->setNextLogger($consoleLogger); return $errorLogger; } $loggerChain = getChainOfLoggers(); /** Error Error::Logger: This is an information. Error Error::Logger: This is an debug information. Error Error::Logger: This is an debug information. Error Error::Logger: This is an error information. Error Error::Logger: This is an error information. Error Error::Logger: This is an error information. */ $loggerChain->logMessage(AbstractLogger::$INFO, "This is an information."); $loggerChain->logMessage(AbstractLogger::$DEBUG, "This is an debug information."); $loggerChain->logMessage(AbstractLogger::$ERROR, "This is an error information.");
  • 相关阅读:
    C# 时间格式化
    新线程匿名方法的新用法
    响应类
    图灵API
    Xpath使用
    Meta http-equiv属性
    CAC的Debian-8-64bit安装BBR正确打开方式
    CAC的Debian-8-64bit安装BBR正确方式是?
    Mbps Mb M Kb如何换算
    如何解决服务器远程桌面连接成功但重启却操作失效?
  • 原文地址:https://www.cnblogs.com/zhouqi666/p/9153556.html
Copyright © 2011-2022 走看看