目录

接下来我们将要谈谈责任链模式,有多个对象,每个对象持有对下一个对象的引用,这样就会形成一条链,请求在这条链上传递,直到某一对象决定处理该请求。

但是发出者并不清楚到底最终那个对象会处理该请求,所以,责任链模式可以实现,在隐瞒客户端的情况下,对系统进行动态的调整

代码示例

<?php

/**
 * Description of ChainDemo
 * 责任链
 * @author jm
 */
class ChainDemo
{
    //put your code here
    public static function main()
    {
        $h1 = new HandlerA();
        $h2 = new HandlerB();
        //设置职责链上下家
        $h1->setSuccessor($h2);
        $requests = [1,5,7,16,25];
        //循环给最小处理者提交请求,不同的数额,由不同权限处理者处理
        foreach ($requests as $value) {
            $h1->handleRequest($value);
        }        
    }
}

abstract class Handler
{
    protected $handler;
    
    //设置继承者
    public function setSuccessor(Handler $handler)
    {
        $this->handler = $handler;
    }
    
    //处理请求的抽象方法
    abstract function handleRequest(int $request);
}
    
//如果可以处理请求,就处理之,否者转发给它的后继者
class HandlerA extends Handler
{
    public function handleRequest(int $request)
    {
        if ($request >=0 && $request < 10)
        {
            echo "HandlerA 处理 $request\n";
        } else if ($this->handler != null) {
             // 转移
            $this->handler->handleRequest($request);
        }
    }
}

class HandlerB extends Handler
{
    public function handleRequest(int $request)
    {
        if ($request >=10 && $request < 20)
        {
            echo "HandlerB 处理 $request\n";
        } else if ($this->handler != null) {
            $this->handler->handleRequest($request);
        }
    }
}

ChainDemo::main();

输出

HandlerA 处理 1
HandlerA 处理 5
HandlerA 处理 7
HandlerB 处理 16

小结

职责链模式, 使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系。将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对像处理它为止。

当用户提交一个请求时,请求是沿着链传递直至有一个对象负责处理它。

接受者和发送者都没有对方的明确信息,且链中的对象自己也并不知道链的结构。结果是职责链可简化对象的相互连接,它们仅需要保持一个向其后继者的引用,而不需要保持它所有的候选者的引用。

随时地增加或修改处理一个请求的结构。增强了给对象指派职责的灵活性。

一个请求极有可能到了链的末端都得不到处理,或者因为没有正确配置而得不到处理。

此处强调一点就是,链接上的请求可以是一条链,可以是一个树,还可以是一个环,模式本身不约束这个,需要我们自己去实现,同时,在一个时刻,命令只允许由一个对象传给另一个对象,而不允许传给多个对象。


本文部分收藏来自互联网,仅用于学习研究,著作权归原作者所有,如有侵权请联系删除

markdown 9ong@TsingChan