草庐IT

compare_exchange_weak

全部标签

c++ - 抑制 -Wtautological-compare 警告

我有一些类似的代码Q_ASSERT(value_which_is_always_smaller_than_4其中Q_ASSERT是Qts断言宏。现在clang,看到这个警告我,因为比较总是正确的。很高兴它可以检测到这一点,但这就是assert语句的重点。我可以以某种方式抑制警告,但只能在断言语句中吗?我仍然希望在其他地方得到警告。 最佳答案 您可以定义一个新宏来包装Q_ASSERT并使用#pragmaclangdiagnosticignored自动消除警告:#defineSTR(x)#x#definePRAGMA(x)_Pragma

c++ - Boost weak_ptr在多线程程序中实现资源池

我正在考虑使用boost::weak_ptr来实现一个对象池,这样当没有人使用其中一个对象时,它们就会被回收。不过,我担心的是,它是一个多线程环境,而且似乎在指向超出范围的对象的最后一个shared_ptr与从weak_ptr构造的新shared_ptr之间存在竞争条件。通常,您会使用锁或其他东西来保护此类操作;然而,这里的重点是您不知道shared_ptr何时可能超出范围。我对boost::shared_ptr和boost::weak_ptr有什么误解吗?如果没有,有人对做什么有什么好的建议吗?谢谢。安德鲁 最佳答案 要使用wea

C++11 static assert for equality comparable type?

如何static_assert模板类型是C++11中的EqualityComparable概念? 最佳答案 您可以使用以下类型特征:#includetemplatestructis_equality_comparable:std::false_type{};templatestructis_equality_comparable()==std::declval(),(void)0)>::type>:std::true_type{};您将以这种方式进行测试:structX{};structY{};booloperator==(Xcon

c++ - 如何将 boost::weak_ptr 转换为 boost::shared_ptr

我有一个shared_ptr和一个weak_ptrtypedefboost::weak_ptrclassnamePtr;typedefboost::shared_ptrxPtr;如何将weak_ptr转换为shared_ptrshared_ptr=weak_ptr;Xptr=classnameptr;????? 最佳答案 已经说过了boost::shared_ptrptr=weak_ptr.lock();如果你不想要异常或者只是使用强制转换构造函数boost::shared_ptrptr(weak_ptr);如果弱指针已经被删除,这

c++ - 为什么在锁定 weak_ptr 时会出现访问冲突?

我有一个std::weak_ptr。在尝试使用底层对象之前,我锁定它以获得shared_ptr:autofoo_sharedptr=foo_weakptr.lock();if(foo_sharedptr!=nullptr){//dostuffwithfoo}通常这很好用。但是,有时我在锁定调用期间遇到访问冲突:Unhandledexceptionat0x00007FF91F411BC3(My.dll)inMy.exe:0xC0000005:Accessviolationreadinglocation0xFFFFFFFFFFFFFFFF.我的猜测是底层指针被删除了,但是我对weak_pt

C++ 模板参数和偏特化 : strong or weak typing?

今天,我和我的一个friend在一个愚蠢的错误上苦苦挣扎,我想知道模板参数在C++中是如何工作的。考虑以下代码,我在其中尝试部分特化类attr>其中I是一个unsignedint,虽然MyClass期望一个int参数:#includetemplateclassMyClass{};templatestructattr;templatestructattr>{};intmain(intargc,char*argv[]){attr>att;return0;}g++失败并显示错误消息main.cpp:Infunction‘intmain(int,char**)’:main.cpp:20:22:

c++ - 使用 shared_ptr 和 weak_ptr 来管理 std::function 的生命周期是否安全?

我已经围绕boost::asio::io_service创建了一个包装器来处理OpenGL应用程序的GUI线程上的异步任务。任务可能是从其他线程创建的,因此boost::asio似乎是这个目的的理想选择,这意味着我不需要编写自己的带有关联互斥锁和锁定的任务队列。我想将每帧完成的工作保持在可接受的阈值以下(例如5毫秒),所以我调用poll_one直到超出所需的预算,而不是调用run.据我所知,这需要我调用reset每当发布新任务时,这似乎运作良好。因为它很短,这里是全部内容,没有#include:typedefstd::functionVoidFunc;typedefstd::share

c++ - 避免 set 创建 Comparator 对象的实际拷贝是否合法

在这样的代码中:Comparatorcomp(3);sets1(comp);sets2(comp);sets3(comp);sets4(comp);Comparator的实际实例(即comp)在每次创建set对象时被复制为cpp引用状态Thecontainerkeepsaninternalcopyofallocandcomp,whichareusedtoallocatestorageandtosorttheelementsthroughoutitslifetime.所以我们想知道这在C++中是否合法#include#includestructA{inti=0;booloperator(

C++ STL 集 : Compare object with extrinsic state

这个定义在OuterClass中:structCompare{booloperator()(constT&,constT&);};typedefsetMySet;我的问题是比较函数operator()取决于OuterClass的状态。(MySet实例在优化算法期间使用,它们必须在不同阶段以不同方式排序。)是否有任何方法/变通方法可以从比较函数operator()中访问OuterClass的非静态成员? 最佳答案 Isthereanyway/workaroundtoaccessnonstaticmembersofOuterClassf

c++ - 从 shared_ptr 到 weak_ptr 多态性的转换

我很难解决这个问题。假设我有这个vectorstd::vector>cars;Car是一个抽象类。我希望能够返回不同类型的弱指针,所以我执行以下操作。templatestd::weak_ptrGetCar(){for(std::vector>::iteratorit=cars.begin();it!=cars.end();++it){T*derived=dynamic_cast((*it).get());if(derived!=nullptr){std::weak_ptrcarPointer=*it;returncarPointer;}}returnstd::weak_ptr();}但