Chinaunix首页 | 论坛 | 博客
  • 博客访问: 253750
  • 博文数量: 60
  • 博客积分: 1222
  • 博客等级: 少尉
  • 技术积分: 585
  • 用 户 组: 普通用户
  • 注册时间: 2011-04-16 17:28
个人简介

从学通信的博士到从事IT行业的工程师 从原华为项目经理,到现任职公司架构师

文章分类

全部博文(60)

文章存档

2013年(18)

2012年(42)

我的朋友

分类: C/C++

2012-12-23 21:04:18

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] [2] [3] 

阅读(2120) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~