草庐IT

unique_future

全部标签

c++ - std::unique_ptr::reset 检查托管指针是否为空?

我一直在阅读有关C++11智能指针的内容,以便在我的源代码中使用它们,我一直在阅读的文档是cppreference.com上的文档;在阅读std::unique_ptr时,在resetfunction上有一个文档对我来说似乎不正确(强调我的):Replacesthemanagedobject.Givencurrent_ptr,thepointerthatwasmanagedby*this,performsthefollowingactions,inthisorder:Savesacopyofthecurrentpointerold_ptr=current_ptr.Overwritest

c++ - std::unique_ptr 转移 const 对象的所有权

我有一个A类的对象在方法内部创建。此方法还创建对象的实例B将对象A作为构造函数参数刚刚创建。B必须取得对象的所有权A但它不能修改它。这意味着AB时应删除被删除,但在B的生命周期内它不能修改A.在本例中为std::unique_ptr作为B的成员变量是转移A所有权的正确方法(在std::move的构造函数中使用B)并保证它不会被修改? 最佳答案 是的,这正是您正在寻找的语义。std::unique_ptr声明“我拥有T对象。”指向constA的指针(原始或智能)声明“我无法修改我指向的A”。总而言之,这正是您所追求的。

c++ - 返回元组时如何转移 unique_ptr 的所有权?

我试图返回一个元组,其中一个元素是std::unique_ptr。我想将unique_ptr的所有权转让给调用者。我该怎么做?#include#include#includeusingnamespacestd;classB{public:B(inti):i_(i){}intgetI()const{returni_;}private:inti_;};tuple,int>getThem(){unique_ptrptr(newB(10));returnmake_tuple(ptr,50);}intmain(intargc,char*argv[]){unique_ptrb;intgot=0;t

c++ - std::unique_ptr<std::array<T,N>> 有用例吗

我遇到了类似的事情:usingarr_t=std::array,1000>,1000>;std::unique_ptru_ptr;显然,使用唯一指针来克服计算器溢出问题。是否有任何情况可以使用以前的代码而不是只使用std::vector?std::unique_ptr>是否有真正的用例?? 最佳答案 上面的代码生成一个包含10亿个元素的连续缓冲区,通过[]访问,您可以将元素作为3维1000面立方体获取。vector的vector将是一整堆由指针和所有权语义链接的非连续缓冲区。我怀疑你在暗示usingu_ptr=std::vector

c++ - 如何存储由 std::unique_ptr 给出的抽象类对象的 vector ?

我有一个循环,在这个循环中我使用一个函数将std::unique_ptr返回给一个抽象类的对象。我想通过push_back将这些对象存储到std::vector中。但由于对象是抽象类型,我得到以下错误:error:cannotallocateanobjectofabstracttype为线cells.push_back(std::move(*cell));其中cells是抽象类型的std::vector而cell是类型std::unique_ptr&&cell(我实际上将cell传递给处理程序类)我知道不能实例化抽象类型,而且我正在理解std:move运算符,它需要以某种方式实例化对象

c++ - 使用 std::unique_ptr 的具有私有(private)析构函数的单例

我在我的程序中创建了所有单例,并牢记该文档:http://erdani.com/publications/DDJ_Jul_Aug_2004_revised.pdf(如果有人想知道为什么单例,它们都是工厂,其中一些存储一些关于它们应该如何创建实例的全局设置)。他们每个人看起来都像这样:声明:classSingletonAndFactory{staticSingletonAndFactory*volatileinstance;public:staticSingletonAndFactory&getInstance();private:SingletonAndFactory();Single

c++ - 有什么方法可以初始化 unique_ptr 的 vector 吗?

例如structA{vector>m_vector{make_unique(1),make_unique(2)};};我尝试了以上但失败了。有什么方法可以初始化unique_ptr的vector? 最佳答案 您不能从初始化列表中移动,因为元素是const.§8.5.4[dcl.init.list]/p5:Anobjectoftypestd::initializer_listisconstructedfromaninitializerlistasiftheimplementationallocatedanarrayofNelement

c++ - 当我们在 vector 上使用 unique 函数时,移位是如何工作的?

所以,我目前正在阅读一些c++的东西,我在cppreference上看到了这个例子,但我不明白转变是如何工作的。#include#include#includeintmain(){std::vectorv{1,2,2,2,3,3,2,2,1};std::vector::iteratorlast;last=std::unique(v.begin(),v.end());//123213221//^for(std::vector::iteratorit=v.begin();it!=last;++it){std::cout我知道当我们使用unique时它会改变事情,但是我不确定我们如何获得从l

c++ - clang,返回带有类型转换的 std::unique_ptr

这是我的代码:#includestructA{};structB:A{};std::unique_ptrtest(){autop=std::make_unique();returnp;}intmain(intargc,char**argv){test();return0;}它不会在clang上编译并出现错误:main.cpp:11:12:error:noviableconversionfromreturnedvalueoftype'unique_ptr>'tofunctionreturntype'unique_ptr>'然而,根据this(同样的情况)应该。我是不是误会了什么?我的命令

c++ - 从 Qt 5.6 切换到 Qt 5.7 - 命名空间 std 中的 "no member ' make_unique'

我有一个CMakeQt项目,它使用了多个c++14功能,包括std::make_unique。通常这将通过以下方式处理:LIST(APPENDCMAKE_CXX_FLAGS-std=c++14)或ADD_COMPILE_OPTIONS(-std=c++14)我想将项目从5.6版升级到5.7版,但在测试构建期间出现多次失败并出现错误nomember'make_unique'innamespacestd我已验证所有适当的header和编译选项都已到位,并排除了任何环境问题。使用Qt5.7绝对是个问题。有什么解决方法吗? 最佳答案 原来这