C++中的异常处理(二)

C++中的异常处理(二)

标签: c++C++异常处理

2012-11-24 20:56 1713人阅读 评论(2) 收藏 举报

 分类:

C++编程语言(24) 

版权声明:本文为博主原创文章,未经博主允许不得转载。

先看下面的代码:

[cpp] view plain copy

  1. int main()
  2. {
  3. int *i=new int(10);
  4. /*
  5. 这中间的代码出现异常
  6. */
  7. delete i;
  8. return 0;
  9. }

如果出现了这样的情况,动态分配的内存就不会被释放。为了处理这样的问题,可以使用C++标准库auto_ptr类。

如果使用下面的代码,内存就一定会被释放

[cpp] view plain copy

  1. #include<memory>
  2. int main()
  3. {
  4. std::auto_ptr<int> ptr(new int(10));
  5. /*
  6. 这中间的代码出现异常
  7. */
  8. return 0;
  9. }

auto_ptr类是接受一个类型形参的模板,它为动态分配的对象提供异常安全。auto_ptr类在头文件memory中定义。

[cpp] view plain copy

  1. auto_ptr<T> ap    创建名为ap的未绑定的auto_ptr对象
  2. auto_ptr<T> ap(p) 创建名为ap的auto_ptr对象,ap拥有指针p指向的对象。该构造函数为explicit
  3. auto_ptr<T> ap1(ap2) 创建名为ap1的auto_ptr对象,ap1保存原来存储在ap2中的指针。ap2将所有权转给ap1,ap2成为未绑定的auto_ptr对象。
  4. ap1=ap2           将所有权转给ap1.删除ap1指向的对象,并使ap1指向ap2指向的对象,使ap2成为未绑定的
  5. *ap               返回ap绑定对象的引用
  6. ap->              返回ap保存的指针
  7. ap.reset(p)       如果p与ap的值不同,则删除ap指向的对象并且将ap绑定到p
  8. ap.release()      返回ap保存的指针并且使ap成为未绑定的
  9. ap.get()          返回ap保存的指针

auto_ptr只能用于管理从new返回的一个对象,它不能管理动态分配的数组。auto_ptr对象在复制和赋值的时候有不同寻常的行为,所以不能将auto_ptr存放到保准库容器类型中。

当auto_ptr对象超出作用域或者被撤销的时候,就会自动释放aotu_ptr保存指针指向对象的内存。

auto_ptr是可以保存任何类型指针的模板

初始化auto_ptr对象的时候,使用如下方法

auto_ptr<int> i(new int(10));

如下初始化是错误的:

auto_ptr<int> i=new int(10);

i所指的由new表达式创建的对象在超出作用域时自动删除。如果i是局部对象,i所指对象在定义i的块的末尾删除;如果发生异常,则i也超出作用域,析构函数将自动运行i的析构函数作为异常处理的一部分;如果i是全局对象,就在程序末尾删除i引用的对象。

如下代码:

auto_ptr<string> ptr(new string("HELLO"));

*ptr="HELLO";   //改变ptr所保存的指针所指对象的内容

string s=*ptr;     //返回ptr所保存指针所指对象

if(ptr->empty())  //判断ptr所指对象是否为空

[cpp] view plain copy

  1. #include<memory>
  2. #include<iostream>
  3. #include<string>
  4. using namespace std;
  5. int main()
  6. {
  7. std::auto_ptr<string> ptr(new string("HELLO"));
  8. /*
  9. 这中间的代码出现异常,内存照样回收
  10. */
  11. cout<<*ptr<<endl;
  12. string s=*ptr;
  13. *ptr="zhycheng";
  14. cout<<*ptr<<endl<<(ptr->empty())<<endl;
  15. /*
  16. 这中间的代码出现异常,内存照样回收
  17. */
  18. return 0;
  19. }

复制auto_ptr对象的时候,如下

auto_ptr<int> ap1(ap2);

那么ap1将获得ap2所保存指针的管理,ap2将会变为未绑定

如果是赋值的话

ap3=pa2;

将删除ap3保存的指针所指对象

ap3置为ap2所指对象

ap2未绑定

如果不给定初始化式,ptr的值为0,对0指针解引用,程序出错并且没有定义会发生什么事。使用VC++的编译器的情况是程序崩溃。

可以使用ptr.get()获得ptr保存的指针来判断ptr是否绑定。

auto_ptr的reset函数接受一个指针,来改变auto_ptr保存的指针,如果新指针与旧指针不同,则删除旧指针所指对象的空间。相同的话就没什么改变。

auto_ptr要注意如下四点:

1.不要使用auto_ptr对象保存指向静态分配内存对象的指针

2.不要使用两个auto_ptr对象保存同一指针

3.不要使用auto_ptr保存动态分配数组的指针

4.不要将auto_ptr对象存储在容器中

时间: 2024-12-26 18:43:29

C++中的异常处理(二)的相关文章

项目中java异常处理

一.java异常类介绍. Throwable: 有两个重要的子类:Exception(异常)和 Error(错误),二者都是 Java 异常处理的重要子类,各自都包含大量子类. 有一篇比较好的blog,http://blog.csdn.net/hguisu/article/details/6155636 介绍java异常. 二.异常处理方式. 在 Java 应用程序中,异常处理机制为:抛出异常,捕捉异常. 三.程序中使用. 2种处理方式 1.throw new 异常  在方法体上写throws

Python基础---python中的异常处理

Python中的异常处理 一.什么是异常处理 python解释器检测到错误,触发异常(也允许程序员自己触发异常) 程序员编写特定的代码,专门用来捕捉这个异常(这段代码与程序逻辑无关,与异常处理有关) 如果捕捉成功则进入另外一个处理分支,执行你为其定制的逻辑,使程序不会崩溃,这就是异常处理. 二.为什么要进行异常处理 python解析器去执行程序,检测到了一个错误时,触发异常,异常触发后且没被处理的情况下,程序就在当前异常处终止,后面的代码不会运行,谁会去用一个运行着突然就崩溃的软件. 所以你必须

数据库基础与ADO.NET和C#中的异常处理

一.数据库基础 1.启动数据库服务--SQLServer(MSSQLSERVER) 方式1: 开始--程序--Microsoft SQL Server 2008 R2  --配置工具--SQL Server 配置管理器--SQLServer服务 方式2: 进入控制面板--管理工具--服务   --找到SQL Server (MSSQLSERVER) 方式3: 开始--运行--输入 services.msc 回车后    进入到 服务列表中,   找到SQL Server (MSSQLSERVER

Delphi中的异常处理(异常来源、处理、精确处理)

一.异常的来源 在Delphi应用程序中,下列的情况都比较有可能产生异常. 1.文件处理 2.内存分配 3.windows资源 4.运行时创建对象和窗体 5.硬件和操作系统冲突 6.网络问题 7.数据库 8.控件中的异常 9.DLL文件的异常 10.强制类型转换 ………… 二.异常的处理 1.try...except...end; 在try 体内的代码发生异常时,系统将转向except 部分进行异常的处理.这是Delphi处理异常的最基本的方式之一. 只有当try 体内的代码发生异常时,才会跳转

Swift中的异常处理

swift中的异常处理 如果在调用系统某一个方法时,该方法最后有一个throws.说明该方法会抛出异常.如果一个方法会抛出异常,那么需要对该异常进行处理 *在swift中提供三种处理异常的方式 方式一:try方式 程序员手动捕捉异常 do { try NSJSONSerialization.JSONObjectWithData(jsonData, options: .MutableContainers) } catch { // error异常的对象 print(error) } 方式二:try

第五章 python中的异常处理

每种编程语言都会有自己的异常处理机制,虽然各有特色,但基本上都差不多,那么python中强大异常处理机制是什么样的呢? 一.异常: python用异常对象来表示异常情况,遇到错误后,会引发异常.如果异常对象并未被处理或捕获,程序会用回溯终止执行: 1 >>> 1/0 2 Traceback (most recent call last): 3 File "<stdin>", line 1, in <module> 4 ZeroDivisionE

C++中的异常处理(一)

来自:CSDN 卡尔  后续有C++中的异常处理(二)和C++中的异常处理(三),C++中的异常处理(二)是对动态分配内存后内部发生错误情况的处理方法,C++中的异常处理(三)中是使用时的异常说明.都易懂易学,值得读!! C++中的异常处理(一) 标签: c++C++exceptionException异常处理 2012-11-23 21:21 5669人阅读 评论(0) 收藏 举报  分类: C++编程语言(24)  版权声明:本文为博主原创文章,未经博主允许不得转载. 异常就是运行时出现的不

Delphi中的异常处理(10种异常来源、处理、精确处理)

一.异常的来源 在Delphi应用程序中,下列的情况都比较有可能产生异常. 1.文件处理 2.内存分配 3.windows资源 4.运行时创建对象和窗体 5.硬件和操作系统冲突 6.网络问题 7.数据库 8.控件中的异常 9.DLL文件的异常 10.强制类型转换 ………… 二.异常的处理 1.try...except...end; 在try 体内的代码发生异常时,系统将转向except 部分进行异常的处理.这是Delphi处理异常的最基本的方式之一. 只有当try 体内的代码发生异常时,才会跳转

二叉树进阶之寻找一棵二叉树中的最大二叉搜索子树

转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6618915.html  (规律:在二叉树中寻找某性质的,都应该以递归思维:从根结点开始递归左右,一直到底,由底向上返回的信息来判断当前结点.求当前结点.即:二叉树的题目,从下往上想,递归的返回过程就是从下往上由叶到根建立二叉树的过程,在此过程中对每一步的"根"结点作性质判断,返回到根时即是整棵树的性质判断了) 从一棵树中寻找结点数最多的二叉搜索子树,并返回这棵子树的头结点. 从题目我们知道以下要求