jjzjj

c++ - 在磁盘上实现的 FIFO 队列(或堆栈),而不是 ram(最好在 C++ 中)

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。基本上,我所追求的是标准模板库队列的等价物,其实现方式是使用磁盘进行存储。需要排队的数据量远远大于当今大多数计算机内存中所能存储的数据量。理想情况下,我正在寻找要使用的图书馆。但是,关于如何实现此队列的任何建议都是有用的。

c++ - 如何使队列上的推送和弹出成为原子操作,如何锁定这些操作?

我正在使用队列在两个线程之间进行通信(一个只是生成自定义类的实例并将指针推送到队列,另一个从自定义类的队列指针中读取并进行一些计算)。如何使队列上的推送和弹出成为原子操作,如何锁定这些操作?(我不能使用C++11标准) 最佳答案 可能最便携的非C++11锁定机制是synchronisztion来自Boost.Thread的类型图书馆。特别是mutex类为您提供了一个简单的可锁定对象,用于授予对资源的独占访问权限。例如:#include#includetemplateclasslocking_queue{public:voidpush

c++ - 无法将派生比较传递给 std::priority_queue

我需要将派生比较器传递给std::priority_queue,但由于某种原因,正在调用基类的operator()。这是显示此行为的最小代码:classBase{public:virtualbooloperator()(intl,intr)const{cout,Base>pq((A()));pq.push(1);pq.push(2);pq.push(3);pq.push(0);coutThecodeisavailableonideoneaswell请注意,我不能使用priority_queue,A>,因为我还有其他子类Base,这将导致大量代码重复1。我做错了什么?如何将比较器传递给将

图灵之旅--ArrayList&顺序表&LinkedList&链表&&栈&&Stack&&队列&&Queue

目录线性表顺序表ArrayList简介ArrayList使用ArrayList的构造ArrayList常见操作ArrayList的遍历ArrayList的扩容机制利用ArrayList洗牌ArrayList的优缺点链表链表的实现双向链表的实现LinkedListLinkedList引入LinkedList的使用LinkedList的构造LinkedList的常用方法介绍LinkedList的遍历ArrayList和LinkedList的区别栈概念栈的使用栈的模拟实现概念区分队列概念队列使用队列模拟实现循环队列双端队列用队列实现栈用栈实现队列线性表线性表是n个具有相同特性的数据元素的有限序列.线

c++ - 使用数组实现一个简单的队列

我对数组、队列和堆栈了解不多。我知道如何实现一个简单的队列。#include#includeusingnamespacestd;voidmain(){queuequeue1;queue1.push('a');queue1.push('b');queue1.push('c');queue1.push('d');while(!queue1.empty()){cout如何使用数组实现简单的队列? 最佳答案 如果您的队列基于数组,那么为了效率起见,我建议创建一个有界或“循环”队列,其中队列的最大大小是固定的,并且您基本上有一个头指针和尾指针

c++ - 通过值获取 std::queue 中元素的索引

有没有一种简单的方法可以通过C++中的值获取元素在std::queue中的位置?例如:std::queuenumbers;numbers.push(7);numners.push(4);numbers.push(11);intposition=numbers.getPosition(4);//shouldbe1 最佳答案 如果你想获得一个元素的索引,你应该考虑使用std::deque容器而不是std::queue容器适配器,正如thisotheranswer中已经建议的那样.如果你还想坚持std::queue由于某些其他原因,容器适

c++ - 如何将 std::queue 转换为 std::vector

我需要使用double队列,因为它作为有序容器具有良好的特性。我想将此队列传递给接受vector的类构造函数。如果我直接这样做,我会收到以下错误:candidateconstructornotviable:noknownconversionfrom'std::queue'to'std::vector&'for2ndargument如何将队列转换为vector? 最佳答案 模拟queue_like行为和vector-like行为的正确容器是std::deque。这样做的好处是:在双端队列的任意一端进行恒定时间插入和删除能够在不破坏双端

c++ - 是否可以按值删除队列元素?

我想从队列中删除具有特定值的元素。如何做这样的事情?(我正在尝试创建映射和队列的并发混合,目前我尝试在thisanswer上实现)所以我目前有这样的代码:#ifndefCONCURRENT_QUEUED_MAP_H#defineCONCURRENT_QUEUED_MAP_H#include#include#include#includetemplateclassconcurrent_queued_map{private:std::map_ds;std::deque_queue;mutableboost::mutexmut_;public:concurrent_queued_map(){

ios - 队列优先级似乎不对

所以我正在测试一些线程代码privatefuncqueuesWithQos(){letqueue1=DispatchQueue(label:"com.appcoda.queue1",qos:.userInitiated)letqueue2=DispatchQueue(label:"com.appcoda.queue2",qos:.utility)queue1.async{print("Queue1thread:\(Thread.current)")foriin0..而且,我认为在这种情况下“我在主队列中”应该首先打印出来,因为它是主线程并且具有最高优先级?但显然,它是最后打印的?我不明

iphone - 当 ASINetworkQueue 完成所有请求时如何显示 UILocalNotification?

我正在使用ASIHTTPRequest在iPhone应用程序在后台运行时下载多个文件。我想在队列结束时显示一个UILocalNotification。在应用程序恢复之前不会调用以下委托(delegate)方法:-(void)queueFinished:(ASINetworkQueue*)aQueue{NSLog(@"Queuefinished");if([[UIApplicationsharedApplication]applicationState]==UIApplicationStateBackground){UILocalNotification*localNotificatio