- 由于C++不支持垃圾自动回收机制,程序员必须手动释放动态申请的空间,否则会发生内存泄漏。为了解决令人头疼的内存泄漏问题,STL引入了智能指针。
- 智能指针实际上是一个类模板,对普通指针进行了一层封装,模板参数是指针指向的类型,通过重载->和*两个操作符使智能指针的用法与普通指针相同。通过析构函数释放指针指向的空间,使得内存管理完全由智能指针自动完成,无须手动释放。
- 由于C++11抛弃了传统的智能指针auto_ptr,因此在新代码中最好不好使用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));//引用计数为1
shared_ptr<int> p2=p1;//引用计数为2
weak_ptr<int> p3=p2;//引用计数仍然为2
- 根据三种智能珠子很的性质不难看出,当对象无须共享所有权时,因该使用unique_ptr独享指针;当对象需要共享所有权时,应该使用shared_ptr;当需要与shared_ptr共享对象所有权而又不想改变引用计数时,应该使用weak_ptr弱指针。