zoukankan      html  css  js  c++  java
  • 22.职责链模式

    职责链模式

    一、职责链模式

    1.基本介绍

    1)职责链模式(Chain of Responsibility Pattern),又叫责任链模式,为请求创建了一个接收者对象的链(简单示意图)。这种模式对请求的发送者和接收者进行解耦。

    2)职责链模式通常每个接收者都包含对另一个接收者的引用。如果一个对象不能处理该请求,那么它会把相同的请求传给下一个接收者,依此类推。

    3)这种类型的设计模式属于行为型模式

    2.原理类图

    1)Handler:抽象的处理者,定义了一个处理请求的接口,同时含义另外Handler

    2)ConcreteHandlerA,B是具体的处理者,处理它自己负责的请求,可以访问它的后继者(即下一个处理者),如果可以处理当前请求,则处理,否则就将该请求交个后继者去处理,从而形成一个职责链

    3)Request,含义很多属性,表示一个请求

    二、应用实例

    1.实例要求

    采购员采购教学器材

    • 如果金额小于等于5000,由教学主任审批

    • 如果金额小于等于10000,由院长审批

    • 如果金额小于等于30000,由副校长审批

    • 如果金额超过30000以上,有校长审批

    2.思路分析

    3.代码实现

    public class Client {
    	public static void main(String[] args) {
    		//创建一个请求
    		PurchaseRequest purchaseRequest = new PurchaseRequest(1, 31000, 1);
    		
    		//创建相关的审批人
    		DepartmentApprover departmentApprover = new DepartmentApprover("张主任");
    		CollegeApprover collegeApprover = new CollegeApprover("李院长");
    		ViceSchoolMasterApprover viceSchoolMasterApprover = new ViceSchoolMasterApprover("王副校");
    		SchoolMasterApprover schoolMasterApprover = new SchoolMasterApprover("佟校长");
    	
    		//需要将各个审批级别的下一个设置好 (处理人构成环形: )
    		departmentApprover.setApprover(collegeApprover);
    		collegeApprover.setApprover(viceSchoolMasterApprover);
    		viceSchoolMasterApprover.setApprover(schoolMasterApprover);
    		schoolMasterApprover.setApprover(departmentApprover);
    		
    		departmentApprover.processRequest(purchaseRequest);
    		viceSchoolMasterApprover.processRequest(purchaseRequest);
    	}
    }
    
    public abstract class Approver {
    	Approver approver;  //下一个处理者
    	String name; // 名字
    	
    	public Approver(String name) {
    		this.name = name;
    	}
    
    	//下一个处理者
    	public void setApprover(Approver approver) {
    		this.approver = approver;
    	}
    	
    	//处理审批请求的方法,得到一个请求, 处理是子类完成,因此该方法做成抽象
    	public abstract void processRequest(PurchaseRequest purchaseRequest);
    }
    
    public class DepartmentApprover extends Approver {
    	public DepartmentApprover(String name) {
    		super(name);
    	}
    	
    	@Override
    	public void processRequest(PurchaseRequest purchaseRequest) {
    		if(purchaseRequest.getPrice() <= 5000) {
    			System.out.println(" 请求编号 id= " + purchaseRequest.getId() + " 被 " + this.name + " 处理");
    		}else {
    			approver.processRequest(purchaseRequest);
    		}
    	}
    }
    
    public class CollegeApprover extends Approver {
    	public CollegeApprover(String name) {
    		super(name);
    	}
    	
    	@Override
    	public void processRequest(PurchaseRequest purchaseRequest) {
    		if(purchaseRequest.getPrice() < 5000 && purchaseRequest.getPrice() <= 10000) {
    			System.out.println(" 请求编号 id= " + purchaseRequest.getId() + " 被 " + this.name + " 处理");
    		}else {
    			approver.processRequest(purchaseRequest);
    		}
    	}
    }
    
    public class ViceSchoolMasterApprover extends Approver {
    	public ViceSchoolMasterApprover(String name) {
    		super(name);
    	}
    	
    	@Override
    	public void processRequest(PurchaseRequest purchaseRequest) {
    		if(purchaseRequest.getPrice() < 10000 && purchaseRequest.getPrice() <= 30000) {
    			System.out.println(" 请求编号 id= " + purchaseRequest.getId() + " 被 " + this.name + " 处理");
    		}else {
    			approver.processRequest(purchaseRequest);
    		}
    	}
    }
    
    //请求类
    public class PurchaseRequest {
    	private int type = 0; //请求类型
    	private float price = 0.0f; //请求金额
    	private int id = 0;
    	//构造器
    	public PurchaseRequest(int type, float price, int id) {
    		this.type = type;
    		this.price = price;
    		this.id = id;
    	}
    	public int getType() {
    		return type;
    	}
    	public float getPrice() {
    		return price;
    	}
    	public int getId() {
    		return id;
    	}
    }
    

    三、注意事项

    1)将请求和处理分开,实现解耦提高系统的灵活性。

    2)性能会受到影响,特别是在链比较长的时候,因此需要控制链中最大节点数量,一般通过在Handler中设置一个最大节点数量。

    3)应用场景:有多个对象可以处理同一个请求时。例如:多级请求,拦截器。

  • 相关阅读:
    # 单调栈 ——Acwing 152. 城市游戏
    # 队列 ——Blah数集(OpenJ_Bailian
    # 队列 ——机器 51Nod
    # 栈 # 队列 ——HDU
    openlayers 为元素添加点击和鼠标悬停事件
    wfs请求filter中判断字段为null的写法
    ArcMap去掉Tiff栅格图层外围的黑色边框
    ArcMap给栅格数据配准并设置坐标系
    ArcMap将线按它的每个节点打散和按照线的相交点打断
    使用turf.js和openlayers配合生成等值面
  • 原文地址:https://www.cnblogs.com/chao-zjj/p/11336748.html
Copyright © 2011-2022 走看看