std::auto_ptr<T>::auto_ptr

来自cppreference.com
< cpp‎ | memory‎ | auto ptr
 
 
 
动态内存管理
未初始化存储
(C++17)
垃圾收集支持
杂项
(C++20)
(C++11)
(C++11)
C 库
低层内存管理
 
 
explicit auto_ptr( X* p = 0 ) throw();
(1) (C++11 中弃用)
(C++17 中移除)
auto_ptr( auto_ptr& r ) throw();
(2) (C++11 中弃用)
(C++17 中移除)
template< class Y >
auto_ptr( auto_ptr<Y>& r ) throw();
(3) (C++11 中弃用)
(C++17 中移除)
auto_ptr( auto_ptr_ref<X> m ) throw();
(4) (C++11 中弃用)
(C++17 中移除)

从指代待管理对象的指针构造 auto_ptr

1) 以指针 p 构造 auto_ptr
2)r 所保有的指针构造 auto_ptr 。调用 r.release() 获取该对象的所有权。
3) 同 (2) 。 Y* 必须可隐式转换为 T*
4)m 所指代的 auto_ptr 实例中保有的指针构造 auto_ptr 。对 m 所保有的 auto_ptr p 调用 p.release() 以获取该对象的所有权。
auto_ptr_ref 是保有到 auto_ptr 引用的实现定义类型。 std::auto_ptr 可隐式转换成此类型并可从它赋值。允许实现以不同的名称提供该模板,或以其他方式实现等价的功能。

[编辑] 参数

p - 指向待管理对象的指针
r - 另一 auto_ptr ,从它传递所有权
m - 保有到 auto_ptr 的引用的实现定义类型对象

[编辑] 注意

源自 auto_ptr_ref 的构造函数和复制赋值运算符允许从无名临时量复制构造和赋值 std::auto_ptr 。因为其复制构造函数与复制赋值运算符以非 const 引用接收参数,它们不能直接绑定右值。然而能执行用户定义转换(释放原 auto_ptr ),之后再调用以值接收 auto_ptr_ref 的构造函数或复制赋值运算符。这是移动语义的早期实现。