智能指针:
为什么要使用智能指针?
由于C++不支持垃圾自动回收机制,程序员必须手动释放动态申请的空间,否则会发生内存泄漏,这无疑对编程提出了更高的要求。为了解决令人头疼的内存泄漏,STL引入了智能指针。
什么是智能指针?
智能指针实际上是一个类模板,对普通指针进行了一层封装,模板参数是指针指向的类型,通过重载 -> 和 *
两个操作使智能指针的用法和普通指针相同。通过析构函数释放指针指向的空间,是的内存管理完全由智能指针自动完成,无须手动释放。
智能指针的粗略介绍:
STL源码:一篇有关智能指针源码的博客
C++11摒弃了auto_ptr,现在最好不要使用了。C++11常用的三个智能指针包括:unique_ptr 独享指针、shared_ptr 共享指针和weak_ptr弱指针。
- 独享指针unique_ptr唯一拥有所指向对象的所有权,不支持拷贝和赋值操作,因此不能用unique_ptr对另一个智能指针初始化或赋值,因只能通过move函数将其所有权转移给其他智能指针,确保不和其他智能指针指向同一个对象。
unique_ptr<int> p1(new int(1));
unique_ptr<int> p2 = p1; //错误,不能进行赋值
unique_ptr<int> p2 = std::move(p1); //正确,可以通过move函数转移所有权
-
共享指针shared_ptr是最常见的智能指针,多个shared_ptr共享所指向对象的所有权,通过引用计数管理指向对同一对象的智能指针个数,每增加一个智能指针指向对象时,引用计数加1,当指向同一对象的所有智能指针的生命周期都结束时,引用计数为0,此时释放对象的内存。
-
弱指针weak_ptr配合shared_ptr一起使用,weak_ptr可以与shared_ptr指向同一个对象,但是不改变引用计数的值。
shared_ptr<int> p1(new int(1));
shared_ptr<int> p2 = p1; //正确,引用计数为2
weak_ptr<int> p2 = p1; //正确,引用计数仍然为2
小结:
- 根据三种智能指针的性质不难看出,当对象无须共享所有权时,应该使用unique_ptr独享指针;
- 当对象需要共享所有权时,应该使用shared_ptr共享指针;
- 当需要与shared_ptr共享对象所有权而又不想改变引用计数时,应该使用weak_ptr弱指针。