c++中的异常处理定义和使用方法

异常处理:

所谓异常处理就是指对运行时出现的差错以及其它例外情况的处理。

C++中处理异常的机制由3部分组成:检查(try),抛出(throw),捕捉(catch)。

例1:求三角形的面积。

程序:

#include<iostream>

#include<cmath>

using namespace std;

double triangle(double a, double b, double c)//定义求三角形面积的函数

{

double s = (a + b + c) / 2;

if (a + b <= c || a + c <= b || b + c <= a)

{

throw a;//不符合三角形条件抛出异常信息a

}

return sqrt(s*(s - a)*(s - b)*(s - c));

}

int main()

{

double triangle(double, double, double);

double a, b, c;

cin >> a >> b >> c;

try//在try块中包括要检查的函数

{

while (a > 0 && b > 0 && c > 0)

{

cout << triangle(a, b, c) << endl;

cin >> a >> b >> c;

}

}

catch (double)//用catch捕捉异常信息并作相应处理

{

cout << "a=" << a << ",b=" << b << ",c=" << c << ",that is not a triangle!" << endl;

}

cout << "end" << endl;

system("pause");

return 0;

}

结果:

6 5 4

9.92157

1 2 1

a=1,b=2,c=1,that is not a triangle!

end

请按任意键继续. . .

例2 在函数嵌套下检查异常处理。

程序:

#include<iostream>

using namespace std;

void f1()

{

void f2();

try

{

f2();

}

catch (char)

{

cout << "ERROR1!";

}

cout << "end1" << endl;

}

void f2()

{

void f3();

try

{

f3();

}

catch (int)

{

cout << "ERROR2!" << endl;

}

cout << "end2" << endl;

}

void f3()

{

double a = 0;

try

{

throw a;//抛出double类型异常

}

catch (float)

{

cout << "ERROR3!" << endl;

}

cout << "end3" << endl;

}

int main()

{

void f1();

try

{

f1();

}

catch (double)

{

cout << "ERROR0!" << endl;

}

cout << "end0" << endl;

system("pause");

return 0;

}

结果:

ERROR0!

end0

请按任意键继续. . .

注意:

a.如果将f3函数的catch子句改为catch (double),程序中其它部分不变,则f3函数中的throw抛出的异常信息立即被f3函数的catch子句捕获,因为抛出的是double型异常信息,输出“ERROR3!”,再执行catch子句后面的语句,输出“end3”。F3函数执行结束后,流程返回f2函数,继续往下执行。运行结果:

ERROR3!

end3

end2

end1

end0

请按任意键继续. . .

b.若将f3函数的catch子句改为:

catch (double)

{

cout << "ERROR3!" << endl;

throw;

}

f3函数中的throw抛出的异常信息a,被f3函数的catch子句捕获,输出“ERROR3!”,但它即用“throw;”将a再抛出,于是a被main函数中的catch子句捕获。

运行输出:

ERROR3!

ERROR0!

end0

请按任意键继续. . .

时间: 2024-10-11 21:45:43

c++中的异常处理定义和使用方法的相关文章

【Android】Android中AsyncTask的定义和使用方法

AsyncTask介绍 Android的AsyncTask比Handler更轻量级一些,适用于简单的异步处理. 首先明确Android之所以有Handler和AsyncTask,都是为了不阻塞主线程(UI线程),且UI的更新只能在主线程中完成,因此异步处理是不可避免的. Android为了降低这个开发难度,提供了AsyncTask.AsyncTask就是一个封装过的后台任务类,顾名思义就是异步任务. AsyncTask直接继承于Object类,位置为android.os.AsyncTask.要使

C# 中函数内定义函数的委托方法

//定义委托方法Action(无返回值)Func(有返回值) //无返回值委托 Action<string> SetKeyAndValue = delegate(string key) { //do something... }; //有返回值委托 Func<string, bool> SetKeyAndValue = delegate(string key) { //do something... return true; };

Javascript中两种最通用的定义类的方法

在Javascript中,一切都是对象,包括函数.在Javascript中并没有真正的类,不能像C#,PHP等语言中用 class xxx来定义.但Javascript中提供了一种折中的方案:把对象定义描述为对象的配方(先看一下例子会比较容易理解).定义类的方法有很多种,这里有两中较为通用的方法,大家参考一下.这两种方法均可以解决 构造函数会重复生成函数,为每个对象都创建独立版本的函数的问题.解决了重复初始化函数和函数共享的问题??提示音:http://www.huiyi8.com/tishiy

JS中定义类的方法&lt;转&gt;

转载地址:http://blog.csdn.net/sdlfx/article/details/1842218 PS(个人理解): 1) 类通过prototype定义的成员(方法或属性),是每个类对象共有的,一般不用来定义成员属性,一个对象修改了属性值,所有对象均被修改: 2) 类拥有prototype属性,类对象没有: 3) 每次new类对象或直接调用类(以下工厂方法形式),都会把定义类(function)的语句执行一次(单例模式可以避免这个情况): 4) 类是function类型,类对象是o

JS中定义类的方法

S中定义类的方式有很多种: 1.工厂方式 function Car(){    var ocar = new Object;    ocar.color = "blue";    ocar.doors = 4;    ocar.showColor = function(){     document.write(this.color)    };    return ocar;   }   var car1 = Car();   var car2 = Car(); 调用此函数时将创建新

类中为什么要定义__init__()方法

总结一下, 加上__init__()方法后,类才可以实例化,不加类就是个空壳,相当于一个方法集合 学习Python的类,一直不太理解为什么一定要定义init()方法,现在简要谈一下自己的理解吧. 1.不用init()方法定义类 定义一个矩形的类,目的是求周长和面积. class Rectangle(): def getPeri(self,a,b): return (a + b)*2 def getArea(self,a,b): return a*b rect = Rectangle() prin

转:python学习——类中为什么要定义__init__()方法

学习Python的类,一直不太理解为什么一定要定义init()方法,现在简要谈一下自己的理解吧. 1.不用init()方法定义类定义一个矩形的类,目的是求周长和面积. 1 class Rectangle(): 2 def getPeri(self,a,b): 3 return (a + b)*2 4 def getArea(self,a,b): 5 return a*b 6 7 rect = Rectangle() 8 print(rect.getPeri(3,4)) 9 print(rect.

Vue-Router路由Vue-CLI脚手架和模块化开发 之 在单文件组件项目中定义数据、方法和组件之间的相互引用

定义数据 根据上一篇博文配置项目的结构的基础上继续进行优化: 在app.vue中的导出模块/组件部分设置其属性: export default{//导出模块/组件 data(){ return{ name:'perfect', count:0 } }, 在一个template标签中进行调用: <template> <div> <h2> 欢迎来到perfect*的博客园!!!</h2> <h3>{{name}}</h3> </te

Java中的异常处理:何时抛出异常,何时捕获异常?

1.如果方法声明名里面有throws异常,那么方法体里面可以不抛出异常.因为可以在方法声明中包含异常说明,但实际上却不抛出!这样做的好处是,为异常先占个位置,以后就可以抛出这种异常而不用修改修改已有的代码.在定义抽象基类和接口时这种能力很重要,这样派生类或接口实现类就能够抛出这些预先声明的异常. 2.为什么有的方法声明里面没有throws,但方法体里面却抛出了异常?从RuntimeException继承的异常,可以在没有异常说明throws的情况下被抛出!对于Runtime异常(也称为非检查的异