智能指针 头文件 memory
必须使用new 分配内存,才可使用。(unique_ptr 支持new[])
auto_ptr
unique_ptr (C++11)
shared_ptr (C++11)
weak_ptr
为避免两个指针指向同一个对象,
auto_ptr 和 unique_ptr 建立所有权(ownership)概念,赋值时所有权转让,unique_ptr 的策略更严格。
auto_ptr 指针相互赋值时源对象所有权被剥夺,试图使用源指针将造成程序崩溃。unique_ptr 不允许这种赋值(编译时错误),但如果源unique_ptr 是个临时右值(如函数返回值),编译器允许这样做。
shared_ptr 采用引用计数策略,赋值时加1,过期时减1,最后一个指针过期时,才调用delete。
* auto_ptr 只能用new 不能用new[], unique_ptr 两个版本都支持。可用std::unique_ptr<double[]> pda(new double[5]);
C++标准库函数 std::move() 能够将一个unique_ptr 赋给另一个。
unique_ptr<string> ps1, ps2;
ps1 = demo("hello!") //该函数返回一个临时unique_ptr对象
ps2 = move(ps1);
ps1 = demo("haha!");
用法
auto_ptr<double> pd(new double);
可进行的操作
解除引用运算符*
取成员运算符->
等等
pd 本身相当于指针
所有智能指针类都有一个explicit 构造函数,因此不能隐式将指针转换为智能指针,必须显式。
可以将智能指针赋给同类型的常规指针
shared_ptr 包含一个显式构造函数,可用于将右值 unique_ptr 转换为 shared_ptr
必须使用new 分配内存,才可使用。(unique_ptr 支持new[])
auto_ptr
unique_ptr (C++11)
shared_ptr (C++11)
weak_ptr
为避免两个指针指向同一个对象,
auto_ptr 和 unique_ptr 建立所有权(ownership)概念,赋值时所有权转让,unique_ptr 的策略更严格。
auto_ptr 指针相互赋值时源对象所有权被剥夺,试图使用源指针将造成程序崩溃。unique_ptr 不允许这种赋值(编译时错误),但如果源unique_ptr 是个临时右值(如函数返回值),编译器允许这样做。
shared_ptr 采用引用计数策略,赋值时加1,过期时减1,最后一个指针过期时,才调用delete。
* auto_ptr 只能用new 不能用new[], unique_ptr 两个版本都支持。可用std::unique_ptr<double[]> pda(new double[5]);
C++标准库函数 std::move() 能够将一个unique_ptr 赋给另一个。
unique_ptr<string> ps1, ps2;
ps1 = demo("hello!") //该函数返回一个临时unique_ptr对象
ps2 = move(ps1);
ps1 = demo("haha!");
用法
auto_ptr<double> pd(new double);
可进行的操作
解除引用运算符*
取成员运算符->
等等
pd 本身相当于指针
所有智能指针类都有一个explicit 构造函数,因此不能隐式将指针转换为智能指针,必须显式。
可以将智能指针赋给同类型的常规指针
shared_ptr 包含一个显式构造函数,可用于将右值 unique_ptr 转换为 shared_ptr