设计模式-职责链模式

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

职责链模式



什么是职责链模式

  将请求的发送和接收解耦,让多个接收对象都有机会处理这个请求。将这些接收对象串成一条链,并沿着这条链传递这个请求,直到链上的某个接收对象能够处理它为止。
  这么说比较抽象,我用更加容易理解的话来进一步解读一下。
  在职责链模式中,多个处理器(也就是刚刚定义中说的“接收对象”)依次处理同一个请求。一个请求先经过 A 处理器处理,然后再把请求传递给 B 处理器,B 处理器处理完后再传递给 C 处理器,以此类推,形成一个链条。链条上的每个处理器各自承担各自的处理职责,所以叫作职责链模式。


为什么要用职责链模式

  应用设计模式主要是为了应对代码的复杂性,让其满足开闭原则,提高代码的扩展性。这里应用职责链模式也不例外。
  我们举例来说明,现在我们有个这样的需求,我们现在的系统分为管理端和终端,管理端可以管控终端软件的安装卸载等,可以在管理端上传安装包,然后下发到终端安装。上传安装包时需要校验安装包是否有病毒:root权限获取、木马、流氓广告弹窗等;使用职责链模式之前的代码可能是这样的:

public class InstallationPackageVirusFilter {
    public boolean filter(InstallationPackageInfo installationPackageInfo) {
        if (!filterRootePrmissioncAquisition(installationPackageInfo)) {
            return false;
        }
        if (!filterTrojanHorse(installationPackageInfo)) {
            return false;
        }
        if (!filterAdvertisingPopUp(installationPackageInfo)) {
            return false;
        }
        return true;
    }

    private boolean filterRootPermissionAcquisition(InstallationPackageInfo installationPackageInfo) {
        // root权限获取
    }

    private boolean filterTrojanHorse(InstallationPackageInfo installationPackageInfo) {
        // 木马
    }

    private boolean filterAdvertisingPopUp(InstallationPackageInfo installationPackageInfo) {
        // 过滤广告弹框
    }
}

  上面这段代码用起来没有问题,那么我们如果需要增加一种病毒类型的检测,那么就需要增加一个if分支并在此类中再增加一个工具方法,这显然是不复合开闭原则的。
  接下来,我们使用职责链模式对这段代码进行优化。


如何使用职责链模式

  职责链模式有两种实现方式,一种是链表形式,一种是数组形式,接下来我们给出两种形式的代码示例。

  • 链表形式的职责链模式
// 安装包病毒过滤器抽象类
public abstract class InstallationPackageVirusFilter {
    // 下一过滤器
    protected InstallationPackageVirusFilter nextFilter = null;

    // 设置下一过滤器
    public void setNextFilter(InstallationPackageVirusFilter nextFilter) {
        this.nextFilter = nextFilter;
    }

    // 执行处理(此处使用模板模式,避免重写时忘记执行nextFilter.handle())
    public final void handle() {
        boolean handled = doHandle();
        if (nextFilter != null && !handled) {
            nextFilter.handle();
        }
    }

    // 具体逻辑
    protected abstract boolean doHandle();
}

// Root权限获取过滤器
public class RootPermissionAcquireFilter extends InstallationPackageVirusFilter{
    @Override
    protected boolean doHandle() {
        // 具体的检测逻辑...
        return false;
    }
}

// 此处省略其他具象类的实现,与Root权限获取过滤器一致
...

// 安装包病毒过滤器链
public class InstallationPackageVirusFilterChain {
    // 链表的头
    private InstallationPackageVirusFilter head = null;
    // 链表的尾
    private InstallationPackageVirusFilter tail = null;

    // 添加过滤器
    public void addHandler(InstallationPackageVirusFilter handler) {
        handler.setNextFilter(null);
        if (head == null) {
            head = handler;
            tail = handler;
            return;
        }
        tail.setNextFilter(handler);
        tail = handler;
    }

    // 执行过滤逻辑
    public void handle() {
        if (head != null) {
            head.handle();
        }
    }
}

// 具体应用
public class Test {
    public static void main(String[] args) {
        InstallationPackageVirusFilterChain chain = new InstallationPackageVirusFilterChain();
        chain.addHandler(new RootPermissionAcquireFilter());
        // 省略其他过滤器的添加
        chain.addHandler(...);
        chain.handle();
    }
}
  • 数组形式的职责链模式
// 安装包病毒过滤器接口
public interface IInstallationPackageVirusFilter {
    boolean handle();
}


// Root权限获取过滤器
public class RootPermissionAcquireFilter implements IInstallationPackageVirusFilter{
    @Override
    public boolean handle() {
        // 具体的检测逻辑...
        return false;
    }
}

// 此处省略其他具象类的实现,与Root权限获取过滤器一致
...

// 安装包病毒过滤器链
public class InstallationPackageVirusFilterChain {
    private final List<IInstallationPackageVirusFilter> handlers = new ArrayList<>();

    // 添加过滤器
    public void addHandler(IInstallationPackageVirusFilter handler) {
        this.handlers.add(handler);
    }

    // 处理
    public void handle() {
        for (IInstallationPackageVirusFilter handler : handlers) {
            boolean handled = handler.handle();
            if (handled) {
                break;
            }
        }
    }
}

// 具体应用
public class Test {
    public static void main(String[] args) {
        chain.chain.InstallationPackageVirusFilterChain chain = new InstallationPackageVirusFilterChain();
        chain.addHandler(new RootPermissionAcquireFilter());
        // 省略其他过滤器的添加
        // chain.addHandler(...);
        chain.handle();
    }
}

  通过上面的代码,我们可以明显感觉到比使用职责链之前的代码简洁,增加一种病毒检测只需要继承/实现指定的抽象类或接口,在使用的时候添加到链中即可。文章来源地址https://www.toymoban.com/news/detail-445169.html


总结

  • 职责链模式可以应对代码的复杂性。
      将大块代码逻辑拆分成函数,将大类拆分成小类,是应对代码复杂性的常用方法。应用职责链模式,我们把各个安装包病毒过滤函数拆分出来,设计成独立的类,进一步简化了 InstallationPackageVirusFilter类,让 InstallationPackageVirusFilter 类的代码不会过多,过复杂。
  • 职责链模式更满足开闭原则,提高代码的扩展性。
      当我们要扩展新的过滤算法的时候,比如,我们还需要过滤扣费,按照非职责链模式的代码实现方式,我们需要修改 InstallationPackageVirusFilter 的代码,违反开闭原则。不过,这样的修改还算比较集中,也是可以接受的。
      而职责链模式的实现方式更加优雅,只需要新添加一个 Filter 类,并且通过 addFilter() 函数将它添加到 FilterChain 中即可,其他代码完全不需要修改。 不过,你可能会说,即便使用职责链模式来实现,当添加新的过滤算法的时候,还是要修改客户端代码(Test),这样做也没有完全符合开闭原则。
      实际上,细化一下的话,我们可以把上面的代码分成两类:框架代码和客户端代码。其中,Test 属于客户端代码,也就是使用框架的代码。除 Test 之外的代码属于敏感词过滤框架代码。 假设敏感词过滤框架并不是我们开发维护的,而是我们引入的一个第三方框架,我们要扩展一个新的过滤算法,不可能直接去修改框架的源码。这个时候,利用职责链模式就能达到开篇所说的,在不修改框架源码的情况下,基于职责链模式提供的扩展点,来扩展新的功能。换句话说,我们在框架这个代码范围内实现了开闭原则。
      除此之外,利用职责链模式相对于不用职责链的实现方式,还有一个好处,那就是配置过滤算法更加灵活,可以只选择使用某几个过滤算法。

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

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

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

相关文章

  • 设计模式—— 单一职责原则

    1,代码重用性(即:相同功能的代码,不用多次编写) 2,可读性(即:编程规范性,便于其他程序员的阅读和理解) 3,可扩展性(当需要增加新的功能时,非常的方便,称为可维护性) 4,可靠性(即:当我们增加新的功能时,对原来的功能没有影响) 5,使程序呈现高内

    2024年02月12日
    浏览(30)
  • 【设计模式之禅】单一职责

    最近前辈推荐我读《设计模式之禅》这本书,原因是我写的代码质量实在是一言难尽,开发速度很快,但是bug数就很多了,设计原则这种知识就需要掌握 写这篇文主要是记录自己的学习以及督促自己 第一章【单一职责】 从我理解的层面来谈谈单一原则:明确每个类每个方法

    2024年02月13日
    浏览(27)
  • 软件设计模式系列之十五——职责链模式

    职责链模式(Chain of Responsibility Pattern)也称为责任链模式,是一种结构型设计模式,用于构建一条对象处理请求的责任链。在这个模式中,多个对象依次处理请求,直到其中一个对象能够处理该请求为止。职责链模式将请求的发送者和接收者解耦,允许多个对象都有机会处理

    2024年02月08日
    浏览(25)
  • 【C++设计模式】单一职责原则

    2023年8月26日,周六上午 目录 概述 一个简单的例子 用单一职责原则来设计一个简单的学生管理系统 单一职责原则(Single Responsibility Principle,SRP),它是面向对象设计中的一个基本原则。 单一职责原则的核心思想是,一个类应该只有一个引起它变化的原因。 换句话说, 一个

    2024年02月11日
    浏览(23)
  • 设计模式—职责链模式(Chain of Responsibility)

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

    2024年02月10日
    浏览(24)
  • 【8】c++设计模式——>单一职责原则

    C++面向对象三大特性之一的 封装 指的就是将单一事物抽象出来组合成一个类,所以我们在设计类的时候每个类中处理的是单一事物而不是某些事物的集合。让类的功能单一,不让类与具体的事物耦合。 设计模式中所谓的单一职责原则,就是对一个类而言,应该仅有一个引起

    2024年02月07日
    浏览(28)
  • 用Rust实现23种设计模式之 职责链模式

    解耦:职责链模式将请求发送者和接收者解耦,使得多个对象都有机会处理请求,而不是将请求的发送者和接收者紧密耦合在一起。 灵活性:可以动态地改变或扩展处理请求的顺序和责任链中的对象。 可维护性:每个处理者只需关注自己的责任,使得代码更易于理解、维护

    2024年02月14日
    浏览(24)
  • 设计模式之职责链模式(ChainOfResponsibility)的C++实现

    在软件开发过程中,发送者经常发送一个数据请求给特定的接收者对象,让其对请求数据进行处理(一个数据请求只能有一个对象对其处理)。如果发送的每个数据请求指定特定的接收者, 将带来发送者与接收者的紧密解耦合问题。职责链模式可以将请求发送者与接收者解

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

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

    2024年02月20日
    浏览(25)
  • 设计模式-职责链模式在Java中使用示例-采购审批系统

    采购审批是分级进行的,即根据采购金额的不同由不同层次的主管人员来审批,主任可以审批5万元以下(不包括5万元) 的采购单,副董事长可以审批5万元至10万元(不包括10万元)的采购单,董事长可以审批10万元至50万元(不包括50万元) 的采购单,50万元及以上的采购单

    2024年02月16日
    浏览(22)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包