C++异常处理
2015-12-23 16:26
274 查看
程序中的错误分为编译时的错误和运行时的错误。编译时的错误主要是语法错误,这类错误比较容易修改,因为编译系统会指出运行错误在第几行,什么错误。而运行时的错误则不容易修改,因为其中的错误是不可预料的,或者可以预料但无法避免,比如内存空间不够,或者在调用函数时,出现数组越界等错误。我们把程序运行时的错误统称为异常,对异常的处理称为异常处理。
C++中所提供的异常处理机制结构清晰,在一定程度上可以保证程序的健壮性。
C++的异常处理机制有3部分组成:try(检查),throw(抛出),catch(捕获)。把需要检查的语句放在try模块中,检查语句发生错误,抛出异常,发出错误信息,由catch来捕获异常信息,并加以处理。一般throw抛出的异常要和catch所捕获的异常类型所匹配。
异常处理的一般格式为:
try
{
被检查语句
throw 异常
}
catch(异常类型1)
{
进行异常处理的语句1
}
catch(异常类型2)
{
进行异常处理的语句2
}
...
下面例子演示了异常处理:
结果:
看了上述的示例代码,也许有人会问,第二个双精度类型的除法计算也应该抛出异常才对啊,在实际的运行过程中并非如此,其实该双精度类型除法函数根本没有被执行过。以上程序的执行规程为:调用函数Div(x,y)时发生异常,由函数Div中的语句"throw y"抛出异常,并不在往下执行return x/y,接着catch捕获int类型的异常并处理异常,最后直接执行"return 0"。因此函数Div(x1,y1)和catch(double){}模块根本没有被执行。如果,我们把y的值改为1,则结果就变成为:
如果在执行try语句模块时,没有发生异常,则catch语句块不起作用,流程转到其后的语句继续执行。从上述两个结果中可知第一次throw抛出的int类型所以找到处理该类型的catch,而第二次是抛出double类型所找到的是处理double类型的catch。
补充几点:(1)try和catch块中必须要用花括号括起来,即使花括号内只有一个语句也不能省略花括号;(2)try和catch必须成对出现,一个try_catch结果中只能有一个try块,但可以有多个catch块,以便与不同的异常信息匹配;(3)如果在catch块中没有指定异常信息的类型,而用删节号"...",则表示它可以捕获任何类型的异常信息;(4)如果throw不包括任何表达式,表示它把当前正在处理的异常信息再次抛出,传给其上一层的catch来处理;(5)C++中一旦抛出一个异常,如果程序没有任何的捕获,那么系统将会自动调用一个系统函数terminate,由它调用abort终止程序。
更详细:http://blog.csdn.net/wangfengwf/article/details/11580817
C++中所提供的异常处理机制结构清晰,在一定程度上可以保证程序的健壮性。
C++的异常处理机制有3部分组成:try(检查),throw(抛出),catch(捕获)。把需要检查的语句放在try模块中,检查语句发生错误,抛出异常,发出错误信息,由catch来捕获异常信息,并加以处理。一般throw抛出的异常要和catch所捕获的异常类型所匹配。
异常处理的一般格式为:
try
{
被检查语句
throw 异常
}
catch(异常类型1)
{
进行异常处理的语句1
}
catch(异常类型2)
{
进行异常处理的语句2
}
...
下面例子演示了异常处理:
#include "stdafx.h" #include <iostream> template <typename T> T Div(T x,T y) { if(y==0) throw y;//抛出异常 return x/y; } int main() { int x=5,y=0; double x1=5.5,y1=0.0; try { //被检查的语句 std::cout<<x<<"/"<<y<<"="<<Div(x,y)<<std::endl; std::cout<<x1<<"/"<<y1<<"="<<Div(x1,y1)<<std::endl; } catch(int)//异常类型 { std::cout<<"除数为0,计算错误!"<<std::endl;//异常处理语句 } catch(double)//异常类型 { std::cout<<"除数为0.0,计算错误!"<<std::endl;//异常处理语句 } return 0; }
结果:
看了上述的示例代码,也许有人会问,第二个双精度类型的除法计算也应该抛出异常才对啊,在实际的运行过程中并非如此,其实该双精度类型除法函数根本没有被执行过。以上程序的执行规程为:调用函数Div(x,y)时发生异常,由函数Div中的语句"throw y"抛出异常,并不在往下执行return x/y,接着catch捕获int类型的异常并处理异常,最后直接执行"return 0"。因此函数Div(x1,y1)和catch(double){}模块根本没有被执行。如果,我们把y的值改为1,则结果就变成为:
如果在执行try语句模块时,没有发生异常,则catch语句块不起作用,流程转到其后的语句继续执行。从上述两个结果中可知第一次throw抛出的int类型所以找到处理该类型的catch,而第二次是抛出double类型所找到的是处理double类型的catch。
补充几点:(1)try和catch块中必须要用花括号括起来,即使花括号内只有一个语句也不能省略花括号;(2)try和catch必须成对出现,一个try_catch结果中只能有一个try块,但可以有多个catch块,以便与不同的异常信息匹配;(3)如果在catch块中没有指定异常信息的类型,而用删节号"...",则表示它可以捕获任何类型的异常信息;(4)如果throw不包括任何表达式,表示它把当前正在处理的异常信息再次抛出,传给其上一层的catch来处理;(5)C++中一旦抛出一个异常,如果程序没有任何的捕获,那么系统将会自动调用一个系统函数terminate,由它调用abort终止程序。
更详细:http://blog.csdn.net/wangfengwf/article/details/11580817
相关文章推荐
- C++ 泛型基础
- C++学习笔记-关联容器
- C++ public,protected,private继承与访问限制
- C中static的用法
- C++11 不抛异常的new operator
- 一个C++钟表小实验
- c语言
- 用C++向一个txt文档中写数据
- 二叉树的遍历C++实现
- 《C++Primer 5e》学习笔记(1):变量和基本类型
- C语言循环和递归两种方法求n的阶乘
- 一、c++上位机与WiFi小车通讯
- 设计模式C++实现--状态模式
- 设计模式C++实现--观察者模式
- 设计模式C++实现--职责链模式
- 设计模式C++实现--中介者模式
- udp如何实现可靠性传输?
- 设计模式C++实现--备忘录模式
- 设计模式C++实现--装饰模式
- 设计模式C++实现--桥接模式