概述
智能指针主要用于管理在堆上分配的内存,它将普通的指针封装为一个栈对象。当栈对象的生存周期结束后,会在析构函数中释放掉申请的内存,从而防止内存泄漏。
C++里面的四个智能指针: auto_ptr, unique_ptr,shared_ptr, weak_ptr,其中后三个是C++11支持,并且第一个已经被C++11弃用。
原理
智能指针的作用是管理一个指针,因为存在以下这种情况:申请的空间在函数结束时忘记释放,造成内存泄漏。使用智能指针可以很大程度上的避免这个问题,因为智能指针就是一个类,当超出了类的作用域是,类会自动调用析构函数,析构函数会自动释放资源。所以智能指针的作用原理就是在函数结束时自动释放内存空间,不需要手动释放内存空间。
技术细节及使用方法
1.auto_ptr
所有权模式,C++11中已经废弃
2.unique_ptr
unique_ptr实现独占式拥有或严格拥有概念,保证同一时间内只有一个智能指针可以指向该对象。它对于避免资源泄露特别有用。
unique_ptr<int> p1(new int(1)); //初始化方式1,注意类的构造函数初始化方式
unique_ptr<int> p2,p3;
p2 = unique_ptr<int>(new int(3)); //初始化方式2,注意这里用来初始化时使用的unique_ptr只是一个临时右值,初始化完就没有归属了,可以这么用
p3 = move(p2); //初始化方式3,将另一个unique_ptr的所有权转让给当前unique_ptr
p2 = unique_ptr<int>(new int(5)); //如果这里不再次初始化p2,后面不能访问p2,因为p2是空指针了
cout<<*p1<<*p2<<*p3<<endl; //输出153
3.shared_ptr
shared_ptr实现共享式拥有概念。多个智能指针可以指向相同对象,该对象和其相关资源会在“最后一个引用被销毁”时候释放。从名字share就可以看出了资源可以被多个指针共享,它使用计数机制来表明资源被几个指针共享。可以通过成员函数use_count()来查看资源的所有者个数。除了可以通过new来构造,还可以通过传入auto_ptr, unique_ptr,weak_ptr来构造。当我们调用release()时,当前指针会释放资源所有权,计数减一。当计数等于0时,资源会被释放。
shared_ptr 是为了解决 auto_ptr 在对象所有权上的局限性(auto_ptr 是独占的), 在使用引用计数的机制上提供了可以共享所有权的智能指针。