1. C98里的智能指针
std::auto_ptr ,本质上是一个普通的指针,通过地址来访问你一个动态分配的对象,初始化时需要传递一个由new操作符返回的对象地址。
std::auto_ptr的析构函数会调用delete操作符,释放掉其包含的对象内存。
智能指针的原理基于一个常见的习语:RAII(资源申请即初始化)。智能指针确保在任何情况下,动态分配的内存都能够得到正确释放,包括程序因为
异常而中断,原本用于释放内存的代码被跳过的场景。用一个动态分配的对象的地址来初始化智能指针,因为析构函数总是会被执行的,则包含的内存就会被释放。
2. 作用域指针
一个作用域指针独占一个动态分配的对象。其类名为:boost::scoped_ptr,一个作用域指针不能传递它所包含的对象的所有权到另一个作用域指针。作用域指针只是简单保存和独占一个内存地址,在不需要所有权传递的时候应该优先使用boost::scoped_ptr。
由于boost::scoped_ptr的析构函数中使用delete操作符来释放所包含的对象,因此boost::scoped_ptr不能用动态分配的数组来做初始化。
3. 作用域数组
与作用域指针相似。不同在于:作用域数组的析构函数使用delete[]操作符来释放所包含的对象,因此该操作符只能用于数组对象,所以作用域数组必须通过动态分配的数组来初始化。
4. 共享指针
boost c++库中,命名为:boost::shared_ptr,定义在boost/shared_ptr.hpp里。共享指针不一定要独占一个对象,可以和其他boost::shared_ptr类型的智能指针共享所有权。在这种情况下,当引用对象的最后一个智能指针销毁后,对象才会被释放。
由于所有权可以在boost::shared_ptr之间共享,任何一个共享指针都可以被复制,则可以在标准容器中存储智能指针;但不能在标准容器中存储std::auto_ptr,因为在拷贝时传递了所有权,离开作用域时,对象会被销毁。
#include <boost/shared_array.hpp> #include <iostream> int main() { boost::shared_array<int> i1(new int[2]); boost::shared_array<int> i2(i1); i1[0] = 1; std::cout << i2[0] << std::endl; //输出1 return 0; }
5. 弱指针
弱指针只有在配合共享指针一起使用时才有意义,boost::weak_ptr定义在boost/weak_ptr.hpp里。
boost::weak_ptr必定总是通过boost::shared_ptr来初始化的,一旦初始化后,它基本上只提供一个有用的方法:lock()。该方法返回的
boost::shared_ptr与用来初始化弱指针的共享指针共享所有权。如果这个共享指针不含有任何对象,返回的共享指针也是空的。
boost::shared_ptr<int> sh(new int(99)); boost::weak_ptr<int> w(sh);
6.指针容器
#include <boost/ptr_container/ptr_vector.hpp> int main() { boost::ptr_vector<int> v; v.push_back(new int(1)); v.push_back(new int(2)); }
boost::ptr_vector专门用于动态分配的对象,使用起来更加高效。boost::ptr_vector独占所包含的对象,因而容器之外的共享指针不能共享所有权,和
std::vector<boost::shared_ptr<int> >相反。