C++11 智能指针
auto_ptr,unique_ptr,shared_ptr,weak_ptr
第一个被C++11弃用,后三个被C++11支持
一. 介绍
智能指针主要用于管理在堆上分配的内存,
它将普通的指针封装为一个栈对象(所以说智能指针实际上是对象),也就是借用了对象的生命周期来对指针进行管理。常用的智能指针为shared_ptr,采用引用计数的方法,记录当前指向的内存资源被多少个智能指针引用,当引用数量为0时,智能指针会自动释放引用的内存资源。
二. 为什么要使用智能指针?
因为程序员常常使用普通指针不规范。
存在申请的空间在函数结束时忘记释放,造成内存泄漏。而使用智能指针可以很大程度上的避免这个问题。因为智能指针是一个类对象,具有相应的生命周期,有析构函数,不需要手动释放内存空间。
三. 具体介绍
1. auto_ptr
C++98的方案,C++11已经抛弃
采用所有权模式。
auto_ptr<string> a(new string("Hello"));
auto_ptr<string> b=a;
b会占有a的指向对象,导致访问a出错
所以存在潜在的内存崩溃问题!
2. unique_ptr
与auto_ptr类似,同一时间只有一个智能指针指向该对象,区别是
unique_ptr<string> a(new string("Hello"));
unique_ptr<string> b=a;
会在编译器出错,保证了安全性
但是可以将临时对象赋给该指针
unique_ptr<string> b=unique_ptr<string>(new string("Hello"));
3. shared_ptr
正如其名,共享的指针,多个智能指针可以指向同一个对象,对象被共享了。采用计数机制管理资源,当引用数为零时释放资源。
shared_ptr<string> a(new string("Hello"));
shared_ptr<string> b=a;
编译通过
4. weak_ptr
之前的智能指针都是用引用计数判断是否释放内存,这存在循环引用,导致内存泄漏的情况,所以weak_ptr诞生了。
weak_ptr是不控制对象生命周期的智能指针,它指向一个shared_ptr指向的对象,由shared_ptr管理该对象的内存,weak_ptr提供访问对象的手段,它主要起协助shared_ptr工作的作用,是对对象的弱引用,不会增加对象的引用计数。
可以从shared_ptr或者另一个weak_ptr构造
shared_ptr<string> a(new string("hello"));
weak_ptr<string> b=a;