php八大设计模式之职责链模式
当发生一种事情时,我们需要要对应职责的事物去处理对应的事情。
或者去找最近的类(就是级别最低的)去解决,如果解决不了就顺着往上找职责更高的,直到解决为止。
注意:一定是要有一个职责最高的类,否则会有问题。
例子:
比如某同学骂人,我们要告诉纪委;旷课我们要告诉班长;打架我们要告诉班主任。不同情况对应不同的人,产生的结果也是不同的,在 php 中我们是怎么实现的呢?
<?php
/**
* 假设:
* 骂人:1
* 旷课:2
* 打架:3
*/
?>
面向过程实现举报:
<?php
//三种情况,该是前台传过来,这儿用数组代替了。
$arr=[1,2,3];
//随机获得一种情况。
array_push($arr,4);
shuffle($arr);
$pop=array_pop($arr);
echo $pop;
//纪委类。
class Dis{
public function go(){
echo "批评"."<br>";
}
}
//班长类。
class Monitor{
public function go(){
echo"扣5分"."<br>";
}
}
//班主任类。
class Headmaster{
public function go(){
echo "叫家长"."<br>";
}
}
if($pop==1){
//如果事态是 1.
$jg=new Dis();
$jg->go();
}else if($pop==2){
//如果事态是 2.
$jg=new Monitor();
$jg->go();
}else{
//如果事态是 3.
$jg=new Headmaster();
$jg->go();
}
?>
职责链模式完成举报功能:
<?php
header("content-type:text/html;charset=utf8");
/**
* 责任链模式完成举报功能。
* 每个对象存储着自己的权限以及上一级的引用,如果自己处理不了,交给上一级。
*/
//应该前台传值过来,这里数组代替。
$arr=[1,2,3];
//随机打乱数组,保证随机性。
shuffle($arr);
//获得数组最后一个值。
$pop=array_pop($arr);
class Dis{ #纪委类。
//权值。
protected $root=1;
//上级。
protected $up="Monitor";
public function go($int){
if($int<=$this->root){
echo "批评"."<br>";
}else{
$this->up=new $this->up;
$this->up->go($int);
}
}
}
class Monitor{ #班长类。
//权值。
protected $root=2;
//上级。
protected $up="Headmaster";
public function go($int){
if($int<=$this->root){
echo "扣5分"."<br>";
}else{
$this->up=new $this->up;
$this->up->go($int);
}
}
}
class Headmaster{ #班主任类。
protected $root=null;
protected $up=null;
public function go(){
echo "叫家长<br>";
}
}
//发生事情去找最近的职责人。
$gos= new Dis();
$gos->go($pop);
?>
管理组模式完成举报:
<?php
header("content-type:text/html;charset=utf8");
/**
* 我认为责任链没有很好的扩展性,在增加新的对应职责人员时,需要修改旧的代码,不符合“开闭原则”。
* 也可以这样实现:
*/
//应该前台传值过来,这里数组代替。
$arr=[1,2,3];
//将管理纳入一个管理组【默认】。
$roots=['Dis','Monitor','Headmaster'];
//纪委类。
class Dis{
public function go(){
echo "批评"."<br>";
}
}
//班长类。
class Monitor{
public function go(){
echo "扣5分"."<br>";
}
}
//班主任类。
class Headmaster{
public function go(){
echo "叫家长<br>";
}
}
//假如新增一个主任类。
class Director{
public function go(){
echo "停课7天<br>";
}
}
//将主任类纳入管理组。
array_push($roots,"Director");
//将事态纳入事态组。
array_push($arr,4);
//随机打乱数组,保证随机性。
shuffle($arr);
//获得数组最后一个值。
//去找对应职责的人。
$pop=array_pop($arr);
$news=new $roots[$pop-1];
$news->go();
?>
php八大设计模式之职责链模式的更多相关文章
- php设计模式之职责链模式
<?php /** * @desc php设计模式之职责链模式(责任链模式) 定义:顾名思义,责任链模式为请求创建了一个接收者对象的链.这种模式给予请求的类型,对请求的发送者和接收者进行解耦.这 ...
- 设计模式之职责链模式(JAVA实现)
学习netty框架时,看到有人说netty用到了设计模式的职责链模式,学习一下职责链模式,主要参考大话设计模式. 主要场景: 小菜想要加薪,向经理提出加薪请求,经理没有权限,经理交由总监处理,总监也没 ...
- 设计模式-利用职责链模式消除if
本文是对职责链设计模式的应用(变种),所以假设读者已经掌握了职责链设计模式,职责链模式只会应景简介. 本文主要内容: 需求(ShitCode) 职责链模式简介 设计理念 代码演示(消除if) 应用总结 ...
- 设计模式:职责链模式(Chain Of Responsibility)
定 义:使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系.将这些对象连成一条链,并沿着这条链传递请求,直到有一个对象处理它为止. 结构图: 处理请求类: //抽象处理类 abs ...
- 设计模式之职责链模式(Chain of Responsibility)摘录
23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于怎样创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而 ...
- 深入理解JavaScript系列(38):设计模式之职责链模式
介绍 职责链模式(Chain of responsibility)是使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系.将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对象 ...
- php实现设计模式之 职责链模式
<?php /** * 职责链模式 * * 为解除请求的发送者和接收者之间的耦合,而使用多个对象都用机会处理这个请求,将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它 * 抽象 ...
- JS常用的设计模式(15)—— 职责链模式
职责链模式是一个对象A向另一个对象B发起请求,如果B不处理,可以把请求转给C,如果C不处理,又可以把请求转给D.一直到有一个对象愿意处理这个请求为止. 打个比方,客户让老板写个php程序.老板肯定不写 ...
- 设计模式之职责链模式(Chain of Responsibility)
职责链模式原理: 职责链模式和装饰模式以及组合模式类似的地方是都维持着指向父类的指针, 不同点是职责链模式每个子类都继承父类的指针及每个之类都维持着指向父类的指针,而组合模式与装饰模式是组合类鱼装饰类 ...
随机推荐
- jqGrid的editrules参数
原文链接:http://blog.csdn.net/mengtianyalll/article/details/13502841 editrules editrules是用来设置一些可用于可编辑 ...
- 07:清泉-改(prime+堆)
时间限制: 10000ms 单个测试点时间限制: 1000ms 内存限制: 512000kB 描述 华北电力大学可以抽象为一张有n个点m条边的无向图. 现在所有的边都断了. 修复每条边都有个不同 ...
- python 3.x 学习笔记13 (网络编程socket)
1.协议http.smtp.dns.ftp.ssh.snmp.icmp.dhcp....等具体自查 2.OSI七层应用.表示.会话.传输.网络.数据链路.物理 3.socket: 对所有上层协议的封装 ...
- Java事件处理机制2
实现一个小程序,怎样让小球受到键盘的控制,上下左右移动,如图: public class Demo3 extends JFrame{ MyPanel mp=null; public static vo ...
- RabbitMq笔记(2)
今天收获不少,记个笔记. namespace RabbitMQTest { class Program { static void Main(string[] args) { Consumer(); ...
- POJ 2739 Sum of Consecutive Prime Numbers【素数打表】
解题思路:给定一个数,判定它由几个连续的素数构成,输出这样的种数 用的筛法素数打表 Sum of Consecutive Prime Numbers Time Limit: 1000MS Memo ...
- 洛谷P3567 [POI2014]KUR-Couriers 主席树
挺裸的,没啥可讲的. 不带修改的主席树裸题 Code: #include<cstdio> #include<algorithm> using namespace std; co ...
- How Javascript works (Javascript工作原理) (六) WebAssembly 对比 JavaScript 及其使用场景
个人总结: 1.webassembly简介:WebAssembly是一种用于开发网络应用的高效,底层的字节码.允许在网络应用中使用除JavaScript的语言以外的语言(比如C,C++,Rust及其他 ...
- vi 学习记录
i 光标所在前插入 I 光标所在行的第一个非空字符前进入输入模式 a 光标所在后插入 A 光标所在最后插入 o 光标所在列下新增一列并进入输入模式 O 光标所在列上新增一列并进入输入模式 退出 :q, ...
- Generator 简介
Generator 就是一种状态机,封装多个内部状态. 执行 Generator 函数会返回一个遍历器对象(),也就是说,Generator 函数除了状态机,还是一个遍历器对象生成函数.返回的遍历器对 ...