草庐IT

auto_ptr_ref

全部标签

c++ - 将 std::vector< std::unique_ptr< int>> 的所有权转移到正在构造的类的正确方法

转让std::vector>所有权的正确方法是什么?到正在构建的类?下面是我想要做的代码表示。我意识到无论是通过值还是通过引用将vector传递给构造函数,它都是不正确的(不会编译)并且违反了“唯一性”。我希望Foo成为vector的新所有者,并希望调用函数放弃所有权。我需要构造函数来获取std::unique_ptr>>这样做?Foo.hclassFoo{public:Foo(vector>vecOfIntPtrsOwnedByCaller);private:vector>_vecOfIntPtrsOwnedByFoo;}Foo.cppFoo::Foo(std::vector>vec

c++ - 将带有自定义删除器的 unique_ptr 移动到 shared_ptr

我有一个函数可以创建一个带有自定义删除器的unique_ptr并返回它:autogive_unique_ptr(){autodeleter=[](int*pi){deletepi;};int*i=newint{1234};returnstd::unique_ptr(i,deleter);}在该函数的客户端代码中,我想将unique_ptr移动到shared_ptr中,但鉴于我不知道该怎么做在函数之外不知道我的自定义删除器的decltype。我猜它应该是这样的:autouniquePtr=give_unique_ptr();autosharedPtr=std::shared_ptr(st

c++ - 将带有自定义删除器的 unique_ptr 移动到 shared_ptr

我有一个函数可以创建一个带有自定义删除器的unique_ptr并返回它:autogive_unique_ptr(){autodeleter=[](int*pi){deletepi;};int*i=newint{1234};returnstd::unique_ptr(i,deleter);}在该函数的客户端代码中,我想将unique_ptr移动到shared_ptr中,但鉴于我不知道该怎么做在函数之外不知道我的自定义删除器的decltype。我猜它应该是这样的:autouniquePtr=give_unique_ptr();autosharedPtr=std::shared_ptr(st

c++ - `new auto` 有什么作用?

当我使用newauto是什么意思?考虑表达式:newauto(5)动态分配对象的类型是什么?它返回的指针是什么类型的? 最佳答案 在这种情况下,auto(5)解析为int(5)。您正在从堆中分配一个新的int,初始化为5。(所以,它返回一个int*)经许可引用AndyProwl的足智多谋的回答:根据C++11标准的第5.3.4/2段:Iftheautotype-specifierappearsinthetype-specifier-seqofanew-type-idortype-idofanew-expression,thenew-

c++ - `new auto` 有什么作用?

当我使用newauto是什么意思?考虑表达式:newauto(5)动态分配对象的类型是什么?它返回的指针是什么类型的? 最佳答案 在这种情况下,auto(5)解析为int(5)。您正在从堆中分配一个新的int,初始化为5。(所以,它返回一个int*)经许可引用AndyProwl的足智多谋的回答:根据C++11标准的第5.3.4/2段:Iftheautotype-specifierappearsinthetype-specifier-seqofanew-type-idortype-idofanew-expression,thenew-

c++ - auto foo = ref new Foo();什么是 "ref"?

我正在观看来自//build/的视频,一些MS开发人员在他们的C++11程序中使用了这样的语法:autofoo=refnewFoo();我了解这一行中除了“ref”之外的所有内容。这是什么意思? 最佳答案 即将推出的VisualC++编译器添加了这种语法来处理WinRT对象(它们又是下一代COM,我们现在经历了什么?COM、DCOM、COM+、ActiveX,...)该行几乎等同于:com_ptr_tfoo=CreateInstance();但是还有一个新版本的com_ptr_t,使用语法Foo^。

c++ - auto foo = ref new Foo();什么是 "ref"?

我正在观看来自//build/的视频,一些MS开发人员在他们的C++11程序中使用了这样的语法:autofoo=refnewFoo();我了解这一行中除了“ref”之外的所有内容。这是什么意思? 最佳答案 即将推出的VisualC++编译器添加了这种语法来处理WinRT对象(它们又是下一代COM,我们现在经历了什么?COM、DCOM、COM+、ActiveX,...)该行几乎等同于:com_ptr_tfoo=CreateInstance();但是还有一个新版本的com_ptr_t,使用语法Foo^。

c++ - shared_ptr 与非指针资源

在C++11中是否可以使用shared_ptr来控制非指针资源?可以使用unique_ptr来管理非指针资源。这是通过实现一个自定义删除器类来完成的,该类提供:一个typedef{TYPE}指针;其中{TYPE}是非指针资源类型operator()(pointer)释放受控资源...然后使用自定义删除器作为第二个模板参数实例化一个unique_ptr。例如,在Windows下,可以创建一个unique_ptr来管理servicecontrolhandle.这个句柄类型不是通过调用delete来释放的,而是通过调用CloseServiceHandle()来释放的。.这是执行此操作的示例代

c++ - shared_ptr 与非指针资源

在C++11中是否可以使用shared_ptr来控制非指针资源?可以使用unique_ptr来管理非指针资源。这是通过实现一个自定义删除器类来完成的,该类提供:一个typedef{TYPE}指针;其中{TYPE}是非指针资源类型operator()(pointer)释放受控资源...然后使用自定义删除器作为第二个模板参数实例化一个unique_ptr。例如,在Windows下,可以创建一个unique_ptr来管理servicecontrolhandle.这个句柄类型不是通过调用delete来释放的,而是通过调用CloseServiceHandle()来释放的。.这是执行此操作的示例代

c++ - 带 auto 的 initializer_list 包含多个表达式

相当简单的问题,autox11{1,2,3,4};autox1={1,2,3,4};autox22{1.0,2.25,3.5};autox2={1.0,2.25,3.5};据我了解,这里是否有=应该没有区别。但是,使用llvm/clang6.0.0(使用--std=c++17),我得到:main1.cpp:35:17:error:initializerforvariable'x11'withtype'auto'containsmultipleexpressionsautox11{1,2,3,4};~~~~~~~~^main1.cpp:37:20:error:initializerfor