人生中总有些事情是不得不做, 于不得不做中勉强去做, 是毁灭; 于不得不做中做的好是勇敢!
19.智能指针
智能指针: 在没有智能指针之前, 获取的资源(例如: 堆的空间)都是通过原生态的指针来管理资源,在资源使用完之后, 必须手动进行释放(忘记释放或者操作有误—>造成资源泄露);
作用: 可以让用户不用关心什么情况下释放资源, 让智能指针自动释放;
RAII: 资源获取即初始化, 在构造函数中获取资源, 在析构函数中将资源释放掉, 以类的方式将资源管理;
智能指针: RAII(管理用户资源)+operator*()/operator->(+解决浅拷贝方式)
C++98: auto_ptr: 资源转移
auto_ptr ap1(new int);
auto_ptr ap2(ap1);将ap1中的资源转移给ap2, ap1与资源断开联系;
缺陷: ap2可以访问资源, ap1不能访问资源;
解决方案: 两个auto_ptr的对象可以同时访问资源
原理: 将资源管理权限转移—>(对资源释放的权利)
缺陷: 可能会造成野指针;
建议: 什么情况下都不要使用智能指针;
C++11:unique_ptr:RAII(管理用户资源)+operator*()/operator->()+一份资源只能被一个对象独占,只需要让unique_ptr防止该类被拷贝;
C++98: 只需将类拷贝构造函数和赋值运算符重载只声明不定义 && 将其访问权限设置为protected或者private;
C++11: 采用delete将默认的拷贝构造函数以及赋值运算符重载删除掉
unique_ptr(const unique_ptr)= delete;
unique_ptr& operator = (const unique_ptr&)= delete;
缺陷: 对象之间不能资源共享;
C++11: shared_ptr—>对象之间可以共享一份资源
实现原理: RAII(管理用户资源)+operator*()/operator->()+引用计数保证资源只释放一次
shared_ptr sp1(new int);
优点: 对象之间可以共享资源;
缺陷: 可能存在循环引用—>后果: 资源泄露
资源的类型: new的堆空间 malloc的堆空间 文件指针 套接字
shared_ptr:定制删除器
让shared_ptr释放资源的方式,可以配置:仿函数,具体资源, 让用户根据资源的类型选择合适的方式进行释放—>将释放的方式提供给shared_ptr
C++11: weak_ptr—>实现原理月shared_ptr相同
作用: 配合shared_ptr解决其循环引用的问题