草庐IT

unique_ptrs

全部标签

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绝对是个问题。有什么解决方法吗? 最佳答案 原来这

c++ - unique_ptr vs 类实例作为成员变量

有一个类SomeClass,它包含一些数据和操作这些数据的方法。并且必须使用一些参数创建它,例如:SomeClass(intsome_val,floatanother_val);还有另一个类,比如Manager,它包括SomeClass,并大量使用它的方法。那么,在性能(数据局部性、缓存命中等)方面会更好,将SomeClass的对象声明为Manager的成员并使用成员初始化在Manager的构造函数中或将SomeClass的对象声明为unique_ptr?classManager{public:Manager():some(5,3.0f){}private:SomeClasssome;

c++ - 任何类型的 unique_ptr 的 static_assert

我如何静态断言表达式是std::unique_ptr即std::unique_ptr对于任何T.static_assert(std::is_pointer()),"notasmartpointer")以上无效。如果没有什么直截了当的,我只对bool()感兴趣运算符是为类型定义的。 最佳答案 通过适当的部分特化创建您自己的特征:templatestructis_unique_ptr:std::false_type{};templatestructis_unique_ptr>:std::true_type{};

c++ - 使用普通函数删除器构建 std::unique_ptr 的包装器

我正在尝试实现一个可以像这样使用的std::unique_ptr工厂:autofd=my_make_unique(fopen("filename","r"));即,将删除函数作为模板参数传递。我在C++11中的最佳尝试是:templatestructDeleter{voidoperator()(P*ptr){deleter(ptr);}};templatestd::unique_ptr>my_make_unique(P*ptr){returnstd::unique_ptr>(ptr);}在C++14中它更简洁:templateautomy_make_unique(P*ptr){stru