C++之泛型编程---有限双端队列结构容器

引言

为了解决工业领域代码容器的通用化,可以考虑C++里的泛型编程概念。假设一个场景需要实时保存最近的n个数据并按照顺序依次处理时,就需要定义一种新的容器来满足要求。当容器不满时,添加数据直接到队尾,当容器数据已经为n个时,需要先删除头,再在队尾插入新元素,以此来不断的保证数据的顺序n个有效。

方案实现

对于C++泛型编程的基础知识可以参考下面两个博客链接

C++之泛型编程-CSDN博客

C++刷题基础知识(栈、队列、hash、STL、基础函数等)---持续更新_c++刷题常用数据结构及方法-CSDN博客

传统的数据结构一般都是指定结构模式的,这样定义数据格式的方式是特定化的,只能应用在特定的系统中,不能实现模块的高度化重用。为了解决这样的问题,通过利用C++泛型编程技术重新定义声明泛型容器结构,以此来做到模块的重复利用,提高软件的代码重用性和框架的适配性。

通过设计有限大小的双端队列容器(LDQC)可以很好地解决上述问题,根据进出队列的模式不同,可以分为先进先出(FIFO)和先进后出(FILO)两种数据传输过程,因此该容器主要包括6大功能函数:数据入队头(enqueuefront)、数据入队尾(enqueuelast)、取队头数据(dequeuefront)、取队尾数据(dequeuelast)、判断容器是否为空(isempty)、容器清空(clear)。其数据流向示意图如图1。

图1 LDQC结构示意图

代码如下:

复制代码
template <typename T>    //泛型声明
class VectorQueue {

public:
    std::deque<T> data;    //声明队列容器
    size_t maxSize;        //声明最大长度
    VectorQueue(size_t size) : maxSize(size) {}

    bool enqueue(const T& value) {
        if (data.size() >= maxSize) {  //判断长度大于等于指定的n时进行先删除在添加
            dequeue();
        }
        data.push_back(value);  //添加队尾元素
        return true;
    }

    bool dequeue() {
        if (data.empty()) {
            return true;
        }
        data.erase(data.begin()); //删除队头元素
        return true;
    }

    bool isEmpty() const {
        return data.empty();
    }

    bool isFull() const {
        return data.size() == maxSize;
    }
};
相关推荐
yangyang_z23 分钟前
【C++设计模式之Strategy策略模式】
c++·设计模式·策略模式
小众AI39 分钟前
fastmcp: 更好用的 MCP Python 框架
开发语言·人工智能·python
cdut_suye43 分钟前
【Linux系统】从零开始构建简易 Shell:从输入处理到命令执行的深度剖析
java·linux·服务器·数据结构·c++·人工智能·python
Tiger Z1 小时前
R 语言科研绘图 --- 桑基图-汇总
开发语言·r语言·贴图
yaoshengvalve1 小时前
V型球阀材质性能深度解析:专攻颗粒、料浆与高腐蚀介质的工业利器-耀圣
开发语言·网络·数据结构·c++·安全·材质
yxc_inspire1 小时前
C++STL在算法竞赛中的应用详解
c++·算法·stl
元亓亓亓1 小时前
Java后端开发day46--多线程(二)
java·开发语言
Kay_Liang2 小时前
深入解析JavaScript变量作用域:var、let、const全攻略
开发语言·javascript·const·var
是店小二呀2 小时前
【算法-哈希表】常见算法题的哈希表套路拆解
数据结构·c++·算法·散列表
jiunian_cn2 小时前
【c++】多态详解
java·开发语言·数据结构·c++·visual studio