由于c和c++中经常出现内存泄漏的问题,所以在c++中引入了智能指针,在对象过期后自动释放内存。
智能指针分类:auto_ptr unique_ptr shared_ptr weak_ptr
如果一个对象被两个智能指针引用,则会出现对象被重复析构的问题?
为解决重复析构造成的错误,有三种策略来解决:
1:赋值构造采取深度拷贝来实现,这样两个指针指向不同的对象,其中一个对象是另一个的副本
2:建立所有权概念,对于特定的对象,只能由一个智能指针可拥有它,这样只有拥有对象的智能指针的析构函数会删除该对象,然后让赋值操作转让所有权。 这就是auto_ptr和unique_ptr的策略,但是unique_ptr的策略更为严格
3:创建智能更高的指针,跟踪引用特定对象的智能指针数。这称为引用计数(reference counting)。例如:赋值时,计数加1,而智能指针过期,计数将减1。仅当最后一个智能指针过期时,才会调用delete。这是shared_ptr采取的策略。
auto_ptr和unique_ptr
auto_ptr是早期版本已经支持的,目前已被摒弃。
unique_ptr采用编译时检测是否造成悬挂指针来避免错误使用,因此unique_ptr比auto_ptr更严格。
shared_ptr和weak_ptr
shared_ptr存在循环引用而导致无法释放的问题,所以引入了weak_ptr来解决这个问题。
weak_ptr作用:判断shared_ptr是否过期;解决循环引用导致无法释放的问题
注:
auto_ptr shared_ptr使用new来创建对象,unique_ptr适用于new和new[]