草庐IT

Make_shared

全部标签

c++ - shared_ptr 的缺点

通过c++11中包含的shared_ptr,可以实现半垃圾收集环境。这种(通货膨胀?)用法是否会带来一些缺点?我可以想象一个类模型,您可以在其中创建一个类,在该类的末尾将您的类定义为shared_ptr以简化语法。/////////////////////MyClass/////////////////////#includeclassMyClass{public:Myclass();};typedefstd::shared_ptrSharedMyClass;///////////////////////////ExampleClass/////////////////////////

c++ - 是否可以强制 `std::make_shared` 使用类的新运算符?

是否可以强制std::make_shared使用类的new运算符?这涉及另一个SOquestion.根据那个问题,std::make_shared使用自定义分配器:Fromthestandard(§20.7.2.2.6shared_ptrcreation):Effects:AllocatesmemorysuitableforanobjectoftypeTandconstructsanobjectinthatmemoryviatheplacementnewexpression::new(pv)T(std::forward(args)...).因此,我认为我可以使用自定义放置新运算符,但这

c++ - 传递给方法时,我应该将 shared_ptr 转换为 weak_ptr 吗?

关于这个主题已经有几个问题,但我仍然不确定该怎么做:我们的代码库在很多地方使用shared_ptr。不得不承认,我们在写的时候并没有明确定义所有权。我们有一些方法,比如voiddoSomething(shared_ptrptr){//doSomething()isamemberfunctionofaclass,butusuallywon'tstoretheptrptr->foo();...}在发现第一个(间接的)循环依赖后,我想纠正我们设计中的错误。但我不确定如何。将上面的方法更改为有什么好处吗?voiddoSomething(weak_ptrptr){shared_ptrptrSha

c++ - 在一组 shared_ptr 中找到一个值

我有一组shared_ptr并想在其中找到一个值:typedefstd::shared_ptrIntPtr;structCompare{booloperator()(constIntPtr&a,constIntPtr&b){return*as;autox=std::make_shared(3);s.insert(x);boolfound=s.find(std::make_shared(3))!=s.end();它可以工作,但效率不高-每次尝试查找值时都需要新的临时指针。还有其他办法吗?看起来像Searchinginasetofshared_ptr有一些可能有用的想法吗?

c++ - 带有大括号初始化的 make_unique

https://en.cppreference.com/w/cpp/memory/unique_ptr/make_unique写道std::make_unique可以实现为templatestd::unique_ptrmake_unique(Args&&...args){returnstd::unique_ptr(newT(std::forward(args)...));}这不适用于没有构造函数的普通结构。这些可以用大括号初始化,但没有非默认构造函数。示例:#includestructpoint{intx,z;};intmain(){std::make_unique(1,2);}Com

c++ - 在同一个线程的同一个实例上多次调用 shared_future::get() 是否合法?

我找不到关于此事的直接确认或反驳。所有答案似乎都解决了“从多线程访问”方面的问题,而不是重复访问本身。标准是否定义了std::shared_future的行为?boost::shared_future怎么样? 最佳答案 根据std::shared_future::valid中的cppreferenceUnlikestd::future,std::shared_future'ssharedstateisnotinvalidatedwhenget()iscalled.这是有道理的。如果不是这种情况,那么您将无法让多个线程调用get。.我

c++ - 如何解决 boost::shared_ptr 和使用 std::shared_ptr 之间的冲突?

如果我在此代码段中从boost::shared_ptr更改为std::shared_ptr,我将收到链接器错误。#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include//usingnamespacestd;//usingnamespaceboost;usingstd::string;usingstd::ostringstre

c++ - 为什么 make_unique 不能与 unique_ptr::reset 一起使用?

我尝试用VS2013编译一些C++代码,unique_ptr::reset()似乎不适用于make_unique();一个小的可编译重现代码片段如下:#includeusingnamespacestd;intmain(){unique_ptrp=make_unique(3);p.reset(make_unique(10));}从命令行编译:C:\Temp\CppTests>cl/EHsc/W4/nologotest.cpp这些是来自MSVC编译器的错误:test.cpp(6):errorC2280:'voidstd::unique_ptr>::reset>>(_Ptr2)':attem

c++ - 如何在 GDB 中访问 std::tr1::shared_ptr 的目标

如何在GDB中访问std::tr1::shared_ptr的目标。这不起作用:(gdb)psharedPtr->variableOfTarget如果我尝试使用指针对象本身(psharedPtr),我会得到如下结果:$1=std::tr1::shared_ptr(count2)0x13c2060使用普通指针,我可以执行p*ptr并获取所有数据或仅获取一个变量的pptr->variable。我在Centos6.5、GCC4.4.7-4.el6和GDB7.2-64.el6_5.2上。 最佳答案 ptr->get()并不总是有效。当我尝试p

c++ - 将 std::shared_ptr 传递给构造函数

关于创建Stuff并赋予Foo所有权,以下是否是一种合理且有效的方法?classFoo{explicitFoo(conststd::shared_ptr&myStuff):m_myStuff(myStuff){}...private:conststd::shared_ptrm_myStuff;}std::shared_ptrfoosStuff(newStuff());Foof(foosStuff); 最佳答案 既然你对效率感兴趣,我想说明两点:shared_ptr是移动构造比复制构造成本更低的许多标准库类型之一。复制构造shared