如何将一个 std::queue 的内容附加到另一个

Posted

技术标签:

【中文标题】如何将一个 std::queue 的内容附加到另一个【英文标题】:How to append the contents of one std::queue to another 【发布时间】:2019-07-12 15:51:47 【问题描述】:

我需要能够将一个 std::queue 的内容添加(附加)到另一个,最好与使用 std::deque::insert 的方式大致相同,但使用 std::vector?我宁愿继续使用 std::vectors,而不是进行重大重写来实现 std::deques。

与我之前在同一个项目中的一些帖子一样,我的流动性有限,因为我可以使用一些遗留代码。大部分限制与速度有关。尽管如此,这个论坛的成员还是提出了一些优雅而独特的解决方案;我希望能找到另一个。

// This works...
std::deque<std::vector<uint8_t>> aaa;
std::deque<std::vector<uint8_t>> bbb;
aaa.insert(aaa.end(), bbb.begin(), bbb.end());

// This, of course, does not work...
std::queue<std::vector<uint8_t>> ccc;
std::queue<std::vector<uint8_t>> ddd;
ccc.insert(ccc.end(), ddd.begin(), ddd.end());

显然不会编译,因为 ccc 类型 std::queue 不支持插入

一些重要说明:永远不会有正在使用的容器(队列、双端队列等)需要 FIFO 以外的任何东西的情况。此外,该处理处理的队列量在每秒 80,000 到 100,000 个元素的范围内,通常非常小,有时非常大。

【问题讨论】:

Merge two std::queue的可能重复 我曾尝试使用 std::list 解决这个问题,但性能指标下降了。我真的很震惊。我确信 std::list 具有重要且有价值的功能,但就此应用程序而言,它不能满足需求。 你真的在追多个std::vector&lt;uint8_t&gt;s吗?从您的问题来看,您似乎正在尝试使用std::vector 作为std::queue 的底层容器,这是不可能的 【参考方案1】:

std::queue 是(默认情况下)std::deque 之上的适配器,专门设计用于删除与 FIFO 队列结构无关的操作。

插入一系列元素,特别是,不是为 FIFO 容器定义的东西,首先使用std::queue 的全部原因是在逻辑上限制操作,而不是 FIFO 容器接口的一部分。

话虽如此,std::queue 公开了它用作受保护成员变量 C 的底层容器,因此解决此限制的一种方法是从 std::deque 继承自定义适配器并公开底层容器。

但是,这在某种程度上违背了目的,您最好直接从std::deque 开始?

【讨论】:

nitpick:std::queue&lt;T&gt;适配std::deque&lt;T&gt;,你也可以有std::queue&lt;T, std::list&lt;T&gt;&gt;【参考方案2】:

我决定进行必要的修改以使用 std::deque。 std::deque 的问题在于它允许从后面移除并推到前面。我们的安全、最佳实践指南强烈建议使用 std::queue 正是出于这个原因。但是我成功地提出了我的案例(在公共汽车下扔了 Stack Overflow 哈哈)。再次感谢大家!

【讨论】:

以上是关于如何将一个 std::queue 的内容附加到另一个的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Discord Py 中将列表附加并保存到另一个文件中?

MFC中,如何将CBitmap中的图片复制到另一CBitmap的一块区域中,即如何读取一个CBit

将数据从一个表附加到另一个 - 语法错误?

SQL 如何复制一条记录的指定字段的内容到另一条记录的指定字段?

如何将一张表复制到另一张表

如何将一个div的内容克隆到另一个div