智能指针
- 内存泄漏
- 动态申请堆空间,忘记归还
- C++语言中没有垃圾回收的机制
- 指针无法控制所指堆空间的生命周期
- 解决思路
- 需要一个特殊的指针
- 指针生命周期结束时主动释放堆空间
- 一片堆空间最多只能由一个指针标识
- 杜绝指针运算和指针比较
- 解决方案
- 重载指针特征操作符
- 只能通过类的成员函数重载
- 重载函数不能使用参数
- 只能定义一个重载函数
- 本质
- 一个对象且在自己生命周期结束时候能删除堆空间,因此只能通过智能指针来指向堆空间中的地址
- 构造
#include<iostream> #include<string> using namespace std; class Person{ public: string m_name; int m_age; Person(string name, int age){ this->m_age = age; this->m_name = name; } }; template<class T> class Pointer{ public: T* mp; Pointer(T* p=NULL){ this->mp = p; } // 以下两行就是为了保证一片堆空间只有一个指针管理 Pointer(const Pointer<T>& p){ mp = p.mp; const_cast<Pointer<T>&>(p).mp = NULL; } Pointer& operator = (const Pointer<T>& p){ if(this != &p){ delete mp; mp = p.mp; const_cast<Pointer<T>&>(p).mp = NULL; } return *this; } T* operator->(){ return mp; } T& operator*(){ return *mp; } bool isNULL(){ if(mp == NULL){ return true; }else{ return false; } } ~Pointer(){ delete mp; cout << "delete" << endl; } }; int main(){ Pointer<Person> pt1 (new Person("zhangsn", 18)); Pointer<Person> pt2 (pt1); return 0; }
- STL库中的智能指针auto_ptr
- 生命周期结束时,销毁指向的内存空间
- 不能指向堆数组,只能指向堆对象(变量)
- 一片堆空间只属于一个智能指针对象
- 多个智能指针对象不能同时指向一片堆空间
- 在头文件memory中
auto_ptr<Person> pt(new Person("zhangsan", 19)); cout << pt->m_name<<endl;
- STL库中其他智能指针
- shared_ptr
- 带有引用计数机制,支持多个指针对象指向同一片内存
- weak_ptr
- 配合shared_ptr而引入的一种智能指针
- unique_ptr
- 一个指针对象指向一片内存空间,不能拷贝构造和赋值
- shared_ptr