智能指针:从std::auto_ptr到std::unique_ptr

std::auto_ptr封装动态申请对象内存返回的指针,并且其行为也和普通指针一样。最重要的一点,程序员不必记得去释放之前申请的内存,当std::auto_ptr销毁时,其封装的指针所指向的内存也会自动销毁。当需要处理异常时,这尤其重要,RAII技术保证异常发生后,在栈上保存的对象依次销毁释放,直至异常被捕获。
当动态申请对象数组时,std::auto_ptr就不在适用了。这是因为std::auto_ptr销毁函数(析构函数)的默认实现是调用delete操作符销毁所封装对象的内存空间(包括调用对象的析构函数),而动态申请的数组需要适用delete[]释放空间(包括调用数组汇总各个对象的析构函数)。如果delete和new操作符不能匹配使用,其结果是不确定的。当然如果申请的数组不是用户定义的数据类型(指int, char等所支持的基本类型),则不存在问题(malloc都是和free匹配使用)。
boost::scoped_array/boost::shared_array是适用于数组的智能指针,不存在上述问题[1]。

std::auto_ptr在最新的c++11标准草案中被std::unique_ptr取代[2,3]。std::unique_ptr支持封装数组动态申请

[1] http://en.highscore.de/cpp/boost/
[2] http://en.wikipedia.org/wiki/C%2B%2B11
[3] "Working Draft, Standard for Programming Language C++"

转载于:https://www.cnblogs.com/hanhuilee/archive/2012/12/15/5221420.html

你可能感兴趣的:(智能指针:从std::auto_ptr到std::unique_ptr)