草庐IT

gray8_ptr_t

全部标签

c++ - 为什么 shared_ptr 有移动构造函数

在C++11中,std::shared_ptr具有移动构造函数和移动赋值运算符。是否有必要这样做的原因,即如果只有复制构造函数和赋值运算符,使用它的任何程序的行为是否会有所不同?它的唯一效果似乎是避免了引用计数器的额外递增和后期递减。 最佳答案 复制一个共享指针是非常昂贵的,因为内部引用计数需要以原子方式修改并使用正确的内存排序,这可能会导致总线锁和栅栏。(回想一下,多个线程可能已经复制了它们自己的、拥有同一对象的本地共享指针。)当您真正想要将所有权从一个对象转移到另一个对象时,这些都不是必需的,移动更胜一筹。

c++ - 将 std::unique_ptr 转换为 std::unique_ptr 到父类(super class)的正确方法是什么?

假设我有一个名为foo的类它继承自一个名为bar的类.我有一个std::unique_ptr到foo的实例我想将它传递给一个只接受std::unique_ptr的函数.我怎样才能转换指针以便它在我的函数中工作? 最佳答案 您可以转换std::unique_ptr右值std::unique_ptr:std::unique_ptrf(newfoo);std::unique_ptrb(std::move(f));显然,指针将由b拥有如果b被摧毁bar需要有一个virtual析构函数。 关于c+

c++ - std::unique_ptr<T[]>::reset 在 gcc 6 中的实现

从C++中的GCC6开始,unique_ptr::reset的声明/定义方法(不是那个,只接受nullptr_t)看起来像这样:template,__and_,is_pointer,is_convertible::type(*)[],element_type(*)[]>>>>>voidreset(_Up__p)noexcept{usingstd::swap;swap(std::get(_M_t),__p);if(__p!=nullptr)get_deleter()(__p);}这在某些时候已更改以实现N4089.根据该文件:Thisfunctionbehavesthesameasthe

c++ - 使用 shared_ptr 在写时复制

所以我有一个简单的cow_ptr.它看起来像这样:template>structcow_ptr:privateBase{usingBase::operator*;usingBase::operator->;usingBase::operatorbool;//etccow_ptr(std::shared_ptrptr):Base(ptr){}//defaultedspecialmemberfunctionstemplatedecltype(auto)write(F&&f){if(!unique())self_clone();Assert(unique());returnstd::forw

c++ - shared_ptr 魔法 :)

Mr.LidströmandIhadanargument:)先生。Lidström的声明是一个构造shared_ptrp(newDerived);不要求Base具有虚拟析构函数:ArmenTsirunyan:"Really?Willtheshared_ptrcleanupcorrectly?Couldyoupleaseinthiscasedemonstratehowthateffectcouldbeimplemented?"DanielLidström:"Theshared_ptrusesitsowndestructortodeletetheConcreteinstance.Thisi

c++ - shared_array 的元素作为 shared_ptr?

如果我有一个boost::shared_array(或boost::shared_ptr),有没有办法获得boost::shared_ptr哪个与数组共享?例如,我可能想写:shared_arrayarray(newint[10]);shared_ptrelement=&array[2];我知道我不能使用&array[2],因为它只有类型int*,这对shared_ptr是危险的有一个将采用该类型的隐式构造函数。理想shared_array上面会有一个实例方法,比如:shared_ptrelement=array.shared_ptr_to(2);很遗憾,我找不到这样的东西。share

c++ - 使用 unique_ptr 进行依赖注入(inject)以模拟

我有一个使用Bar类的Foo类。Bar仅在Foo中使用,而Foo正在管理Bar,因此我使用unique_ptr(不是引用,因为我不需要Foo之外的Bar):usingnamespacestd;structIBar{virtual~IBar()=default;virtualvoidDoSth()=0;};structBar:publicIBar{voidDoSth()override{coutbar):bar_(std::move(bar)){}voidDoIt(){bar_->DoSth();}private:unique_ptrbar_;};目前一切顺利,一切正常。但是,当我想对代

c++ - shared_ptr 原子函数采用指针而不是引用的基本原理

如你所见here,shared_ptr作为指针而不是引用传递。还要注意Allthesefunctionsinvokeundefinedbehaviorifpisanullpointer.那么为什么是指针呢?我认为在C++中,应该优先使用引用,除非有特定的原因需要使用指针。 最佳答案 templateboolatomic_is_lock_free(conststd::shared_ptr*p);接受一个指向智能指针的指针,因为这是更通用的atomic_is_lock_free的特例:templateboolatomic_is_lock

c++ - 有没有办法更改现有 shared_ptr 实例的删除操作

我有一个函数,我希望在90%的时间内完成清理操作,但在10%的时间内我希望完成一些其他操作。有什么方法可以使用一些标准范围的控件,例如shared_ptr这样一开始它可以有一个删除操作,然后在函数中可以更改删除操作?shared_ptrptr(newT,std::mem_fun_ref(&T::deleteMe));ptr.pn.d=std::mem_fun_ref(&T::queueMe); 最佳答案 不是真的-shared_ptr的标准以这样的方式编写Deleter可以按值存储在控制节点(一个包含引用计数器、保存删除器、跟踪弱指

c++ - 为什么即使给定了模板参数,ptr_fun 也会发现这种模棱两可的情况?

所以,这里有一些基本代码可以说明我的问题:#includeintfunc(intx){returnx;}intfunc(intx,inty){returnx+y;}intmain(){std::ptr_fun(func);}对于具有不同数量参数的函数,我们有2个重载。然后我尝试在仿函数中转换单参数版本。当然,我遇到了以下错误:test.cc:Infunction'intmain()':test.cc:13:29:error:callofoverloaded'ptr_fun()'isambiguous/usr/lib/gcc/x86_64-pc-linux-gnu/4.5.2/inclu