Java设计模式—责任链模式(Chin of Responsibility)

这篇具有很好参考价值的文章主要介绍了Java设计模式—责任链模式(Chin of Responsibility)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前言

一、责任链模式的简介

二、责任链模式的概念

三、责任链模式的作用

四、责任链模式的优、缺点

1.责任链模式的优点

2.责任链模式的缺点

五、责任链模式的应用场景

六、代码案例

UML类图

 1.定义一个请求枚举类

 2.定义一个请求类

3.定义一个抽象处理接口

4、定义具体处理类

5.Main代码测试

总结


前言

使用责任链模式,它可以动态地添加或删除处理器,从而改变处理请求的顺序和方式。同时,责任链模式也可以减少对象之间的耦合度,提高代码的可扩展性和可维护性。


一、责任链模式的简介

责任链模式(Chin of Responsibility)是一种行为型设计模式,它通过将请求的发送者和接收者解耦来实现请求的处理。


二、责任链模式的概念

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


三、责任链模式的作用

责任链模式(Chin of Responsibility)的作用是将请求的发送者和接收者解耦,使多个对象都有机会处理该请求。它将这些对象连接成一条链,并沿着链传递请求,直到有一个对象处理它为止。

责任链模式的主要作用包括以下:

  1. 降低系统的耦合度
  2. 增强系统的灵活性
  3. 提高代码的可扩展性
  4. 提高代码的可维护性

四、责任链模式的优、缺点

1.责任链模式的优点

  1. 降低系统的耦合度:请求发送者和接收者之间不直接交互,而是通过责任链上的多个对象进行交互,从而降低了它们之间的耦合度。
  2. 增强系统的灵活性:可以动态地增加或删除处理器,从而改变请求的处理顺序和方式。
  3. 提高代码的可扩展性:因为每个处理器都只负责处理自己能够处理的请求,所以可以方便地添加新的处理器来处理新的请求类型。
  4. 提高代码的可维护性:因为每个处理器都只负责处理自己能够处理的请求,所以可以方便地添加新的处理器来处理新的请求类型。

2.责任链模式的缺点

  1. 请求可能没有被处理:如果没有任何一个处理器能够处理该请求,则该请求将被忽略。
  2. 系统性能可能受影响:由于责任链中可能包含大量的处理器,因此可能会影响系统的性能。

五、责任链模式的应用场景

责任链的使用场景有以下几点:

  1. 处理请求需要多个对象协作,且不确定哪个对象能够处理请求。
  2. 需要动态指定能够处理请求的对象集合。
  3. 需要在不明确接收者的情况下,向多个对象中的一个或多个发送请求。
  4. 可以通过在运行时添加或删除处理器来改变请求处理的顺序。
  5. 当一个请求需要被多个对象进行处理时,可以使用责任链模式避免产生复杂的嵌套调用。
  6. 可以将责任链模式与其他设计模式结合使用,如装饰器模式、工厂模式等,以实现更加灵活的功能。

六、代码案例

UML类图

Java设计模式—责任链模式(Chin of Responsibility)

 1.定义一个请求枚举类

RequestType请求枚举

/***
 * 定义请求枚举
 */
public enum RequestType {
    TYPE_A, TYPE_B, TYPE_C
}

 2.定义一个请求类

Request请求类

/***
 * 定义请求类
 */
public class Request {
    private String name;
    private RequestType type;

    public Request(String name, RequestType type) {
        this.name = name;
        this.type = type;
    }

    public String getName() {
        return name;
    }

    public RequestType getType() {
        return type;
    }
}

3.定义一个抽象处理接口

定义一个抽象处理器(Handler)类,其中包含一个指向下一个处理器的引用,并定义一个处理请求的方法。

Handler抽象类

/***
 * 定义一个抽象处理器(Handler)类,其中包含一个指向下一个处理器的引用,并定义一个处理请求的方法。
 */
public abstract class Handler {
    protected Handler successor;

    public void setSuccessor(Handler successor) {
        this.successor = successor;
    }

    public abstract void handleRequest(Request request);
}

4、定义具体处理类

ConcreteHandlerA类

/***
 * 定义具体处理类
 */
public class ConcreteHandlerA extends Handler {

    @Override
    public void handleRequest(Request request) {
        if (request.getType().equals(RequestType.TYPE_A)) {
            System.out.println("ConcreteHandlerA处理请求" +request.getName());
        } else if (successor != null) {
            successor.handleRequest(request);
        }
    }
}

ConcreteHandlerB类

/***
 * 定义具体处理类
 */
public class ConcreteHandlerB extends Handler {

    @Override
    public void handleRequest(Request request) {
        if (request.getType().equals(RequestType.TYPE_B)) {
            System.out.println("ConcreteHandlerB处理请求" + request.getName());
        } else if (successor != null) {
            successor.handleRequest(request);
        }
    }

ConcreteHandlerC类

/***
 * 定义具体处理类
 */
public class ConcreteHandlerC extends Handler {

    @Override
    public void handleRequest(Request request) {
        if (request.getType().equals(RequestType.TYPE_C)) {
            System.out.println("ConcreteHandlerC处理请求" + request.getName());
        } else if (successor != null) {
            successor.handleRequest(request);
        }
    }
}

5.Main代码测试

 public static void main(String[] args) {
        Handler handlerA = new ConcreteHandlerA();
        Handler handlerB = new ConcreteHandlerB();
        Handler handlerC = new ConcreteHandlerC();

        handlerA.setSuccessor(handlerB);
        handlerB.setSuccessor(handlerC);

        Request request1 = new Request("已处理 1", RequestType.TYPE_A);
        Request request2 = new Request("已处理 2", RequestType.TYPE_B);
        Request request3 = new Request("已处理 3", RequestType.TYPE_C);

        handlerA.handleRequest(request1);
        handlerA.handleRequest(request2);
        handlerA.handleRequest(request3);
    }

输出结果:

Java设计模式—责任链模式(Chin of Responsibility)

 


总结

这个示例中,具体处理器类实现了抽象处理器接口,并根据自己的能力来判断是否能够处理请求。如果不能处理,则将请求传递给下一个处理器。客户端创建责任链并将请求发送给第一个处理器,处理器依次处理请求,直到有一个处理器能够处理它为止。文章来源地址https://www.toymoban.com/news/detail-480470.html

到了这里,关于Java设计模式—责任链模式(Chin of Responsibility)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【设计模式-05】Facade门面Mediator调停者 | Decorator装饰器 | Chain Of Responsibility责任链

    一般是系统内部相互交错,比如 消息中间件(MQ) 就是这种设计模式,对各个功能或系统之间进行解耦。 业务场景:论坛或者博客发表帖子或者评论,对敏感词过滤处理。使用责任链的模式进行过滤处理。 把变化的进行封装处理 核心代码实现 GitHub - jxaufang168/Design-Patterns: 设计

    2024年01月19日
    浏览(111)
  • 设计模式—职责链模式(Chain of Responsibility)

    目录 思维导图 什么是职责链模式? 有什么优点呢? 有什么缺点呢? 什么场景使用呢? 代码展示 ①、职责链模式 ②、加薪代码重构 使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这个对象连成一条链,并沿着这条链传递该请求,直到有

    2024年02月10日
    浏览(37)
  • 设计模式--职责链模式(Chain of Responsibility Pattern)

    职责链模式(Chain of Responsibility Pattern)是一种行为设计模式,它为请求创建了一个接收者对象的链。 这种模式给予请求的类型,对请求的发送者和接收者进行解耦。这种类型的设计模式属于行为型模式。 在职责链模式中,通常每个接收者都包含对另一个接收者的引用。如果

    2024年02月20日
    浏览(37)
  • 责任链模式(Chain of Responsibility)

    责任链模式是对象的行为模式。使多个对象都有机会处理请求,从而避免请求的发送者和接受者直接的耦合关系。

    2024年02月05日
    浏览(48)
  • 责任链模式(Chain of Responsibility)

    命令链(Chain of Command)。 责任链是一种行为设计模式 , 允许你将请求沿着处理者链进行发送。收到请求后,每个处理者均可对请求进行处理,或将其传递给链上的下个处理者 。 1. 问题 假如你正在开发一个在线订购系统。你希望对系统访问进行限制, 只允许认证用户创建

    2024年02月11日
    浏览(39)
  • Java设计模式-责任链模式

    责任链模式,有的地方也会叫职责链模式。它指的是,为请求者和被请求者之间创建一条对象处理链路,避免请求发送者与接受者耦合在一起。 在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链。请求在这个链上传递,直到链上的某一个对象决定

    2024年02月15日
    浏览(44)
  • Java设计模式——责任链模式

    当一个请求需要在多个对象之间传递,每个对象都可能处理该请求或将其传递给下一个对象。在这种情况下,需要避免将发送者与接收者之间的耦合,以及确定请求的处理方式。此时可使用责任链模式,它的优点有降低耦合度(无需关心哪个对象会处理请求),灵活性(可以

    2024年02月21日
    浏览(46)
  • java设计模式(十五)责任链模式

    责任链模式(Chain of Responsibility) 使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有对象能够处理它。 抽象处理类: 主要包含一个指向下一处理类的成员变量 nextHandler 和一个处理请求的方

    2024年02月08日
    浏览(51)
  • 设计模式之责任链模式【Java实现】

    责任链(chain of Resposibility) 模式:为了避免请求发送者与多个请求处理者耦合在一起,于是将所有请求的处理者 通过前一对象记住其下一个对象的引用而连成一条链 ;当有请求发生时,可将请求沿着这条链传递,直到有对象处理它位置。属于对象行为型模式。 抽象处理者

    2024年02月12日
    浏览(47)
  • 【Java 设计模式】行为型之责任链模式

    责任链模式(Chain of Responsibility Pattern)是一种行为型设计模式,用于将请求发送者和接收者解耦,使得多个对象都有机会处理请求。责任链模式通过创建一个处理请求的链,将请求沿着链传递,直到有一个对象能够处理为止。在本文中,我们将深入研究Java中责任链模式的定

    2024年01月24日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包