草庐IT

atomic_shared_ptr

全部标签

c++ - 如何将 boost::shared_ptr<T> 后面的完整对象深度复制到指向新位置的 shared_ptr?

如何在boost::shared_ptr后面复制完整对象:是否有memcopy选项(只创建内存克隆),或者我们应该创建复制构造函数? 最佳答案 您需要一个复制构造函数或一个将执行深复制的operator=。boost::shared_ptr无法知道您的对象的结构来为您执行此操作。“内存克隆”操作也不能。当然,这仅适用于需要明确定义的复制构造函数/operator=的对象,而“普通”的对象会进行浅拷贝。 关于c++-如何将boost::shared_ptr后面的完整对象深度复制到指向新位置

c++ - 如何使具有 unique_ptr 成员的类与 std::move 和 std::swap 一起工作?

我有课。它有一个unique_ptr成员。classA{std::unique_ptrm;};我希望它适用于以下语句Aa;Ab;a=std::move(b);std::swap(a,b);如何制作?根据评论,我有一个问题。这个编译器依赖吗?如果我什么都不做,它无法通过VC++2012的编译。我试过structA{A(){}A(A&&a){mb=a.mb;ma=std::move(a.ma);}A&operator=(A&&a){mb=a.mb;ma=std::move(a.ma);return*this;}unique_ptrma;intmb;};但不确定这是否是最好和最简单的方法。

c++ - 在使用 libstdc++ 进行调试期间强制在 std::atomic 中使用锁

我已经做了一些谷歌,似乎无法为此打开一个GCC选项或libstdc++宏。是否可以在所有std::atomic模板特化上强制使用内部锁定。在某些平台上,一些特化无论如何都会被锁定,因此这看起来确实是一个可行的选择。在过去,我发现使用std::atomic在使用诸如Valgrind(Helgrind或DRD),因为大量的误报。如果原子学的使用足够普遍,抑制文件似乎不是一个非常可扩展的解决方案。 最佳答案 没有办法,AFAIK。GCC通过无锁内置函数(__atomic_fetch_add、__atomic_test_and_set等)实

c++ - 如何避免 VS 中 unique_ptr 检查的性能警告?

这段代码:unique_ptra;if(a){cout甚至这段代码:unique_ptra;if(static_cast(a)){cout导致此警告:warningC4800:'void(__cdecl*)(std::_Bool_struct&)':forcingvaluetobool'true'or'false'(performancewarning)with[_Ty=std::unique_ptr]在VisualStudio2012中,警告级别为3。在第一条评论之后,我发现它只有在公共(public)语言运行时支持/clr被打开时才会发生。我应该如何避免它?if(a.get()!=

c++ - unique_ptr 指向指针的删除器指针

我正在尝试使用unique_ptr自定义删除器映射第三方API。问题是API是这样的:x*x_alloc_x(void);voidx_free_x(x**p);API要我提供一个指向它的指针的指针,以便将其设置为NULL。我一直在编写我的deleter仿函数作为对指针的引用,我使用“&”运算符将其转换为指针对指针。structXDeleter{voidoperator(x*&p){x_free_x(&p);}};这适用于GCC4.6,但标准实际上允许这样做吗?如果没有,是否有符合标准的方法将此API映射到删除器? 最佳答案 代码格式

c++ - 如何确保返回 vector <unique_ptr> 的常量

我问了相关问题here.现在它有点微妙。代码如下:classMyClass{public:constvector>&get_const_objs()const;private:vector>m_objs;};我的意图是从get_const_objs()返回的vector是只读的,但问题是因为vector的元素不是常量,所以调用者仍然可以更改单个元素,例如constvector>&objs=pMyClass->get_const_objs();unique_ptrp=move(objs[0]);我的解决方案是向vector中插入常量:constvector>&get_const_objs

c++ - 为什么 unique_ptr 对 auto_ptr 有重载?

我遇到编译器错误并注意到一些有趣的事情。出于某种原因,unique_ptr对auto_ptr有重载,但我认为auto_ptr已被弃用:/usr/local/include/c++/4.9.0/bits/unique_ptr.h:228:2:note:templatestd::unique_ptr::unique_ptr(std::auto_ptr&&)unique_ptr(auto_ptr&&__u)noexcept;/usr/local/include/c++/4.9.0/bits/unique_ptr.h:228:2:note:templateargumentdeduction/s

c++ - 在同一个对象上创建多个 shared_ptr "families"时 shared_from_this 的意外行为

下面是一些示例代码(在线here):#includestructFoo:publicstd::enable_shared_from_this{};voidexample(){autosharedFoo=std::make_shared();std::shared_ptrnonDeletingSharedFoo(sharedFoo.get(),[](void*){});nonDeletingSharedFoo.reset();sharedFoo->shared_from_this();//throwsstd::bad_weak_ptr}我看到的(在多个编译器下)是当nonDeleting

c++ - Doxygen 能否识别 std::shared_ptr 或 std::map

是否可以教Doxygen识别类型为std::shared_ptr的成员?作为聚合?我认为它适用于普通指针,尽管我添加了BUILTIN_STL_SUPPORT=YES.问题还扩展到std::unique_ptr这应该是一个组合,我认为std::map,std::vectoretc可以记录为具有多重性1...N的组合,尽管我很确定我不希望在所有情况下都这样。如果Doxygen做不到这一点,我会对C++的替代文档系统感兴趣。 最佳答案 从版本1.8.14开始,Doxygen不添加std::shared_ptr当BUILTIN_STL_SU

c++ - 除了重新抛出 std::exception_ptr 之外,我还能做什么

我有一个std::exception_ptr类型的对象,我想在它上面调用what(),但似乎没有办法做到这一点(如本答案中所述:HowdoImakeacalltowhat()onstd::exception_ptr)。在互联网上搜索后,似乎除了重新抛出它并在std::exception&中捕获它之外我无法对它做任何事情。这对我来说有点奇怪,但我想检查一下:std::exception_ptr可以做什么,然后重新抛出它以获得期望的细节?C++14或其他版本的C++有什么变化 最佳答案 不幸的是,没有。该标准仅保证std::except