std::auto_ptr<T>::auto_ptr
来自cppreference.com
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() 以获取该对象的所有权。参数
p | - | 指向待管理对象的指针 |
r | - | 另一 auto_ptr ,从它传递所有权
|
m | - | 保有到 auto_ptr 的引用的实现定义类型对象
|
注解
源自 auto_ptr_ref
的构造函数和复制赋值运算符允许从无名临时量进行 std::auto_ptr 的复制构造和赋值。因为其复制构造函数与复制赋值运算符以非 const 引用接收实参,所以它们不能直接绑定右值。然而,可以执行用户定义转换(释放原 auto_ptr
)之后再调用按值接收 auto_ptr_ref
的构造函数或复制赋值运算符做到这点。这是一种移动语义的早期实现。