草庐IT

c++ - 将派生类的 unique_ptr 添加到基类 unique_ptr 的 vector 中

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭6年前。Improvethisquestion我有一个std::unique_ptr我想添加到std::vector>.std::unique_ptrderivedObject;std::vector>vec;vec.push_back(derivedObject)//Invalidarguments

c++ - 这是对 unique_ptr 的误用吗?

我正在转向智能指针,并努力确保正确使用它们。有很多问题涵盖了何时使用每个问题,但我找不到专门关于getter的问题。我有一个拥有指针的类,我希望其他类能够访问该指针(逐步重构遗留代码)。我想给这个类一个unique_ptr因为它只会拥有那个对象,但它们不能被复制。我应该返回对unique_ptr的引用,还是只使用shared_ptr?classB{public:doAction(){};};classA{private:std::unqiue_ptrpointer;public:std::unique_ptr&GetPointer(){returnpointer;}};a.GetPoi

c++ - 制作 shared_ptr 的拷贝时会发生什么?

我想了解当将shared_ptr分配给另一个时,shared_ptr中托管对象的引用计数会受到怎样的影响。我在C++primer,5thedition中看到以下声明:Forexample,thecounterassociatedwithashared_ptrisincrementedwhen...weuseitastheright-handoperandofanassignment...Thecounterisdecrementedwhenweassignanewvaluetotheshared_ptr...举个例子:autop=make_shared(42);//objecttowh

c++ - 如何深度复制 unique_ptr 的 vector

我有一个带有数据成员的容器类。std::vector>Functions;我想在我的复制构造函数中做一个深拷贝,我怎样才能做一个std::unique_ptr的深拷贝。 最佳答案 std::vector>copiedFunctions;std::for_each(Functions.begin(),Functions.end(),[&](std::unique_ptrf){copiedFunctions.push_back(std::make_unique(*f));}));这意味着Sum_Function当然有一个复制构造函数。

c++ - 分配给 shared_ptr,有没有办法做到这一点?

有没有办法首先用nullptr初始化shared_ptr并在一段时间后将指向类的指针赋值给它?//pseudocodestd::shared_ptrptr(nullptr);//andlaterptr->assign(newMyClass); 最佳答案 你在寻找ptr.reset(newMyClass)吗? 关于c++-分配给shared_ptr,有没有办法做到这一点?,我们在StackOverflow上找到一个类似的问题: https://stackover

c++ - 如何将 std::unique_ptr<> 从一个 STL 容器移动到另一个?

问题我有一个模板容器MyContainer>它有一个std::deque和一个std::vector成员(member)。内部方法,send_to_purgatory_if(predicate),我想查看m_taskdq中的所有项目并从m_taskdq移动项目至m_purgatory,如果谓词的计算结果为真。问题我有两个问题正在努力解决:我的迭代器it如果我从循环内从m_taskdq中删除项目,则会被丢弃我很担心std::unique_ptr的状态如果我分两步进行移动(问题第1行和第2行-通过第2行,我认为std::unique_ptr指向的it未定义?)我应该如何修复此代码?temp

c++ - 流畅的接口(interface)模式和 std::unique_ptr

我正在玩fluentinterface模式。首先,我写了这样的东西:classC{public:C(){}C*inParam1(intarg1){param1=arg1;returnthis;}C*inParam2(intarg2){param2=arg2;returnthis;}private:intparam1;intparam2;}然后我尝试使用std::unique_ptr,但后来我意识到我不知道如何沿着链“移动”指针(this)。我试过类似的东西:returnstd::move(this);那当然不行。我该怎么做?这样做有什么问题吗?为了回复诸如“不要使用指针”之类的评论:(

c++ - 用于将 weak_ptr 应用于 unique_ptr 的内容

我试图理解c++11中的unique_ptr、shared_ptr和weak_ptr。我听说weak_ptr对于缓存和中断循环等事情会很好。我听说它们与shared_ptrs配合得很好。但是在这方面,shared_ptrs和unique_ptrs有什么区别呢?为什么weak_ptr只能与一个一起使用而不能与另一个一起使用?为什么我不想对其他人拥有的东西进行弱引用? 最佳答案 weak_ptr在技术上是一种卡在管理某些共享对象的一组shared_ptr的引用计数器上的方法。当最后一个shared_ptr被销毁时,对象被销毁,但只要有w

c++ - Qt::make_shared 用于创建 QSharedPtr 和 std::make_shared 用于创建 std::shared_ptr

正如BjarneStroustrup的“C++之旅”中所述,作为一种已知的C++14实践,人们应该避免在代码中使用裸露的new和delete。标准库提供std::make_shared和std::make_unique用于创建智能指针以立即将分配的对象存储在其中。但是,不能将这些例程用于非标准智能指针,例如在Qt中。Qt有自己的内存管理模型(带父对象),但也提供智能指针类,如QSharedPointer和QPointer(尽管后者实际上不是拥有指针)。我的问题是:创建std::make_shared的Qt类似物不是很方便吗?像这样,创建QSharedPtr:namespaceQt{te

c++ - 为 std::shared_ptr 分配内存的正确方法

我已经实现了一个功能,在这个功能中,身份是交给我的,不受我的控制。它返回std::shared_ptr.在函数中,我分配了任意数量的内存,并通过shared_ptr返回对它的访问。我的内存分配是用newunsignedchar[123]完成的.问题是valgrind检测到新变体和删除变体的使用不匹配。当我使用new[](unsigned)为了分配内存,shared_ptr析构函数使用delete(void*)释放它,每当您使用“不正确”的分配器进行分配时,valgrind都会发出警告。更实际地说,我写了这个测试用例来说明我的意思:TEST(Example,Test1){unsigned