smart pointer:
unique_ptr只能有一个指针指向某块内存区域。
1.不支持赋值和复制构造
unique_ptr<int> ap(new int(88));
unique_ptr<int> aa(ap);出错
unique_ptr<int> bb(aa));出错
2.可以移动构造和移动赋值
在函数中作为返回值可以用
unique_ptr<int> Getval{
unique_ptr<int> up(new int(88));
return up;
}
unique_ptr<int> uPtr = GetVal(); //ok
unique_ptr<int> uPtr2 = std:move( up) ; //这里是显式的所有权转移. 把up所指的内存转给uPtr2了,而up不再拥有该内存
3.可以作为容器元素
我们知道auto_ptr不可做为容器元素.而unique_ptr也同样不能直接做为容器元素,但可以通过一点间接的手段
unique_ptr<int> sp(new int(88) );
vector<unique_ptr<int> > vec;
vec.push_back(std::move(sp));
//vec.push_back( sp ); 这样不行,会报错的.
#include <iostream>
#include <memory>
struct Foo
{
Foo(){std::cout<<"Foo:Foo\n";}
~Foo(){std::cout<<"Foo::~Foo\n";}
void bar(){std::cout<<"Foo::bar\n";}
};
void f(const Foo&)
{
std::cout<<"f(const Foo&)\n";
}
int main()
{
//struct Foo *p = new Foo;
std::unique_ptr<Foo> p(new Foo());
if(p)
p->bar();
std::unique_ptr<Foo> pt(std::move(p)); //forced into a right value
f(*pt);
p = std::move(pt);
if(p)
p->bar();
return 0;
}
[root@localhost C++]# ./a.out
Foo:Foo
Foo::bar
f(const Foo&)
Foo::bar
Foo::~Foo
code from:http://en.cppreference.com/w/cpp/memory/unique_ptr