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;
    }
};
相关推荐
得物技术20 分钟前
搜索 C++ 引擎回归能力建设:从自测到工程化准出|得物技术
c++·后端·测试
xlp666hub21 小时前
Leetcode 第三题:用C++解决最长连续序列
c++·leetcode
会员源码网1 天前
构造函数抛出异常:C++对象部分初始化的陷阱与应对策略
c++
xlp666hub1 天前
Leetcode第二题:用 C++ 解决字母异位词分组
c++·leetcode
不想写代码的星星1 天前
static 关键字:从 C 到 C++,一篇文章彻底搞懂它的“七十二变”
c++
xlp666hub2 天前
Leetcode第一题:用C++解决两数之和问题
c++·leetcode
不想写代码的星星2 天前
C++继承、组合、聚合:选错了是屎山,选对了是神器
c++
不想写代码的星星3 天前
std::function 详解:用法、原理与现代 C++ 最佳实践
c++
樱木Plus5 天前
深拷贝(Deep Copy)和浅拷贝(Shallow Copy)
c++
blasit7 天前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip