《过滤器模式(极简c++)》

本文章属于专栏- 概述 - 《设计模式(极简c++版)》-CSDN博客


本章简要说明过滤器模式。本文分为**++模式说明、本质思想、实践建议、代码示例++**四个部分。

模式说明

方案: 过滤器模式是一种结构型设计模式,用于过滤一组对象,基于特定条件筛选出所需的对象。

优点:

  1. 松耦合性: 过滤器模式将过滤条件与具体操作解耦,使得条件的变化不影响其他部分。
  2. 可组合性: 可以轻松地组合多个过滤器以实现复杂的过滤逻辑。

缺点:

  1. 类数量增加: 可能会引入过多的具体过滤器类,增加代码复杂度。
本质思想:过滤器模式的本质思想是将过滤条件封装到对象中,然后使用这些对象对原始数据进行过滤,以获取符合条件的结果集。
实践建议:在过滤器很多时。定义一个通用的过滤器接口,以便不同类型的过滤器都可以实现该接口。在需要经过多层过滤时,多个过滤器组合在一起形成过滤链,以实现复杂的过滤需求。这样过滤逻辑集中在一个类中,更方便管理和维护。

示例代码

cpp 复制代码
#include <iostream>
#include <vector>

// 基类 Bird
class Bird {
public:
    virtual bool filter() const = 0;
    virtual ~Bird() {}
};

// 具体类:鸟类
class Sparrow : public Bird {
public:
    bool filter() const override { return true; } // 飞行鸟
};

class Penguin : public Bird {
public:
    bool filter() const override { return false; } // 水中鸟
};

// 具体过滤器:飞行鸟过滤器
class FlyingBirdFilter {
public:
    bool filter(const Bird& bird) const {
        return bird.filter();
    }
};

// 过滤器使用示例
int main() {
    std::vector<Bird*> birds = {new Sparrow(), new Penguin()};
    FlyingBirdFilter flyingFilter;

    for (Bird* bird : birds) {
        if (flyingFilter.filter(*bird)) {
            std::cout << "This bird can fly." << std::endl;
        }else {
            std::cout << "This bird can't fly." << std::endl;
        }
    }

    for (Bird* bird : birds) {
        delete bird;
    }

/*
输出:
    This bird can fly.
    This bird can't fly.
*/

    return 0;
}
相关推荐
程序员小寒4 分钟前
JavaScript设计模式(六):职责链模式实现与应用
java·javascript·设计模式
Hello-FPGA9 分钟前
视觉软件工程师(机器视觉 / 科学成像方向)
c++
Lhan.zzZ17 分钟前
Qt开发踩坑:QList越界问题导致程序崩溃
数据库·c++·qt
code_whiter27 分钟前
C\C++5(内存管理)
c语言·c++
无籽西瓜a1 小时前
【西瓜带你学设计模式 | 第五期 - 建造者模式】建造者模式 —— 产品构建实现、优缺点与适用场景及模式区别
java·后端·设计模式·软件工程·建造者模式
HABuo1 小时前
【linux线程(二)】线程互斥、线程同步、条件变量详细剖析
linux·运维·服务器·c语言·c++·ubuntu·centos
Rabitebla1 小时前
归并排序(MergeSort)完全指南 —— 从原理到非递归实现
c语言·数据结构·c++·算法·排序算法
墨^O^1 小时前
进程与线程的核心区别及 Linux 启动全过程解析
linux·c++·笔记·学习
福楠1 小时前
现代C++ | C++14甜点特性
linux·c语言·开发语言·c++
WBluuue1 小时前
Codeforces Educational 188(ABCDEF)
c++·算法