我正在转向智能指针,并努力确保正确使用它们。有很多问题涵盖了何时使用每个问题,但我找不到专门关于getter的问题。我有一个拥有指针的类,我希望其他类能够访问该指针(逐步重构遗留代码)。我想给这个类一个unique_ptr因为它只会拥有那个对象,但它们不能被复制。我应该返回对unique_ptr的引用,还是只使用shared_ptr?classB{public:doAction(){};};classA{private:std::unqiue_ptrpointer;public:std::unique_ptr&GetPointer(){returnpointer;}};a.GetPoi
我有一个带有数据成员的容器类。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当然有一个复制构造函数。
问题我有一个模板容器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
我正在玩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);那当然不行。我该怎么做?这样做有什么问题吗?为了回复诸如“不要使用指针”之类的评论:(
我想知道是否有一种有效的方法可以根据对象成员字段的值从容器中删除对象。例如,我可以使用带有字符串列表的STL::unique执行以下操作:#include#include#include#includeusingnamespacestd;boolstringCompare(conststring&l,conststring&r){return(l==r);}intmain(){listmyStrings;myStrings.push_back("1001");myStrings.push_back("1001");myStrings.push_back("81");myStrings.
我试图理解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
我们有一个广泛的代码库,目前使用原始指针,我希望迁移到unique_ptr。但是,许多函数期望原始指针作为参数,并且在这些情况下不能使用unique_ptr。我意识到我可以使用get()方法来传递原始指针,但这会增加我必须接触的代码行数,而且我觉得它有点难看。我推出了自己的unique_ptr,如下所示:templateclassmy_unique_ptr:publicunique_ptr{public:operatorT*(){returnget();};};然后每次我向需要原始指针的函数parm提供my_unique_ptr时,它都会自动将其转换为原始指针。问题:这样做有什么内在的
使用std::unique_ptr&有什么好处吗?而不是std::unique_ptr?例如,在函数参数中? 最佳答案 有几种不同的情况您想将所有权转移给函数使用std::unique_ptr您想允许函数修改指针使用std::unique_ptr&您想允许函数修改指针对象使用T&,并在调用站点取消引用如果指针可能为空,则使用T*并调用unique_ptr::get在调用站点你想让函数观察指针对象使用constT&,并在调用站点取消引用如果指针可能为空,则使用constT*并调用unique_ptr::get在调用站点你想让函数拥有指
我正在尝试使用unique_ptr实现BST。我得到了shared_ptr的工作程序。我该如何着手使用unique_ptr来强制执行BinarySearchTree的单一所有权语义?当我将shared_ptr替换为unique_ptr时,出现了我无法理解的编译错误。#include#includetemplateclassBinarySearchTree{structTreeNode;typedefstd::shared_ptrspTreeNode;structTreeNode{Tdata;spTreeNodeleft;spTreeNoderight;TreeNode(constT&v
这是正确的方法吗?voidhelperFunc(MyClass*ptr){//dosomethingwithptr,}unique_ptrp(newMyClass());helperFunc(p.get());或者我应该使用shared_ptr进行此类操作吗? 最佳答案 除非你想获得内存的所有权(在这种情况下你应该传递shared_ptr或unique_ptr),你为什么要使用指针?通过引用传递。voidhelperFunc(MyClass&obj){//dosomethingwithptr,}unique_ptrp(newMyCl