一、为什么使用智能指针
为管理内存等资源,C++采取RAII机制(资源获取即初始化,Resource Acquisition Is Initialization),在使用资源的类的构造函数中申请资源并使用,最终在析构函数中释放资源。使用new在堆上创建对象时,其析构函数不会自动调用,需要使用delete才能释放资源,若因为异常导致程序未能执行delete,则存在内存泄露的问题。C++98标准中的“自动指针std::auto_ptr(C++11中废弃,改用unique_ptr)部分解决了获取资源自动释放的问题。
二、boost库提供的智能指针
boost.smart_ptr库提供六种智能指针,包括socped_ptr、scoped_array、shared_ptr、shared_array、weak_ptr和intrusive_ptr。他们都是轻量级的对象,速度与原始指针相差无几,都是异常安全的,而且对于所指向的类型T也仅有一个很小且合理的要求:类型T的析构函数不能抛出异常。
头文件:#include<boost/smart_ptr.hpp>
scoped_ptr | 保证智能指针只能在本作用域中使用,拥有对象的唯一所有权,不可以复制。如果一个类中有scoped_ptr成员变量,则该类也不可拷贝或赋值。 | <boost/scoped_ptr.hpp> |
scoped_array | 类似scoped_ptr,只不过包装的是new[ ]操作符,不推荐使用 | <boost/scoped_array.hpp> |
shared_ptr | 实现了引用计数,可以拷贝或赋值,当引用计数为0时自动删除动态分配的对象 | <boost/shared_ptr.hpp> |
shared_array | 类似shared_ptr,但包装的是new[ ]分配的动态数组 | <boost/shared_array.hpp> |
weak_ptr | 配合shared_ptr而引入,不具备普通指针的行为,作为shared_ptr拥有对象的非拥有观察者 |