jjzjj

c++ - C++11 中的泛型函数指针

我目前正在用C++x0编写一个方法执行队列。我已经实现并验证了基本的队列机制,但想用一个选项来修改它,让push()自动删除所有以前对特定方法的调用:queue.push(this,&Obj::foo,1);queue.push(this,&Obj::foo,2);queue.push(this,&Obj::foo,3);应该和调用一样queue.push(this,&Obj::foo,3);到目前为止,我的代码如下所示:队列.h:#pragmaonce#include#includeusingstd::vector;usingstd::function;usingstd::bind;

c++ - 这个入队功能是如何工作的?

我无法理解这一行:rear->next=temp;在这个队列函数中:voidQueue::enqueue(intdata){Node*temp=newNode();//makeatemporarynodetemp->info=data;//assignpassedindatatoittemp->next=0;//makeitpointtonullif(front==0)//ifthereisnofrontnodefront=temp;//makethisafrontnodeelse//else,ifthereisalreadyafrontnoderear->next=temp;//ma

c++ - 为什么这个自定义比较器在构造 std::priority_queue 时失败,而它适用于 std::sort?

比较器comp定义如下。它适用于std::sort,但无法在std::priority_queue的构造函数中编译。问题是什么?谢谢。#include#include#includeusingnamespacestd;boolcomp(inta,intb){returna>b;}intmain(){vectorvec={4,2,1,3};sort(vec.begin(),vec.end(),comp);//OKpriority_queueq1(less(),vec);//OKpriority_queueq2(comp,vec);//Failreturn0;}错误信息:error:nom

C++ 在 priority_queue 中使用 std::greater() 并排序

为什么这两种情况的文档说的是同一件事,但它们以相反的方式声明,一个使用greater而另一个使用greater().任何人都可以解释一下吗?文档priority_queuecpplibrary说那个compcanbeComparisonobjecttobeusedtoordertheheap.Thismaybeafunctionpointerorfunctionobjectpriority_queue,greater>minheap;//workspriority_queue,greater()>minheap;//whyfail?文档cpplibrarysort说的是同一件事,即co

c++ - "expected unqualified-id"上的 "using"编译失败

我需要一些帮助来制作这个类(class)程序。我们正在使用g++(linux?它是通过服务器上的putty)我对这个链表有很多问题。它给我的当前错误是queue.cpp:2:error:expectedunqualified-idbeforeâusingâ想知道是否有人可以帮我解决这个问题。一点点搜索表明问题似乎出在#define的某个地方?错误显示它在.cpp文件中,但我认为它在.h文件中。另外,如果你能给我任何关于任何看起来不对劲、错误的编程建议,或者是否有更好的方法。下面的queue.h文件#ifndefQUEUE_H#defineQUEUE_HtemplateclassQueu

C++ std::queue 不想 push()

这是一个简单的类和简单的测试函数:#include#includenamespace{usingnamespacestd;}classNameStream{queuestream;public:stringoperator*(){returnstream.front();}NameStream&operator++(int){stream.pop();return*this;}NameStream&operator++(){stream.pop();return*this;}NameStream&operator它落在NameStream&operator在队列的推送过程中,这是我的代

c++ - 如何初始化一个有n个默认值的队列?

假设我有一个带有默认构造函数的类。如何通过设置其大小和默认值在构造函数中初始化队列。classStandardClass{};//willinitializeavectorwith5defaultstandardclassstd::vectorvec(5,StandardClass());如何对队列执行相同的操作?std::queueque(5,StandardClass());??? 最佳答案 如果您查看例如thisstd::queueconstructorreference你会看到你可以传递底层容器的实例(默认为std::deq

c++ - 互斥体能否在不显式保护对象的情况下确保对象的线程可见性?

考虑以下代码,尽管线程都引用相同的指针,但线程是否可能以不同的方式查看对象的状态?usingnamespacestd;classProducerAndConsumer{classDummyObject{public:DummyObject(){sprintf(a,"%d",rand());}private:chara[1000];};mutexqueue_mutex_;queuequeue_;thread*t1,*t2;voidProduce(){while(true){Sleep(1);//constructingobjectwithoutanyexplicitsynchroniza

c++ - 从 priority_queue 弹出时出现排序问题,这是 std::priority_queue 的错误吗

#include#include#include#includestructTemp{intp;std::stringstr;};structTempCompare{booloperator()(Tempconst&a,Tempconst&b){returna.p>b.p;}};intmain(){std::priority_queue,TempCompare>pq;//EnableandDisablethefollowinglinetoseethedifferentoutput//{Tempt;t.p=8;t.str="str1";pq.push(t);}{Tempt;t.p=8;t

c++ -/boost/lockfree/queue.hpp: 错误: 静态断言失败: (boost::has_trivial_destructor<T>::value)

我正在尝试替换boost::lockfree::queue对于std::queue在这个文件中https://github.com/zaphoyd/websocketpp/blob/experimental/examples/broadcast_server/broadcast_server.cpp我添加了#include;改线130,std::queuem_actions;,至boost::lockfree::queuem_actions;;删除所有与锁定有关的行;并更改了行103,m_actions.pop();,至m_actions.pop(a);.我在sconsbroadcas