std::auto_ptr<T>::auto_ptr
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
的构造函数或复制赋值运算符。这是移动语义的早期实现。