c++中try catch的用法小结

2020-01-06 18:59:37王振洲

在c++中,可以直接抛出异常之后自己进行捕捉处理,如:(这样就可以在任何自己得到不想要的结果的时候进行中断,比如在进行数据库事务操作的时候,如果某一个语句返回SQL_ERROR则直接抛出异常,在catch块中进行事务回滚(回滚怎么理解?))。


#include <iostream> 
#include <exception> 
using namespace std; 
int main () { 
 try 
 { 
  throw 1; 
  throw "error"; 
 } 
 catch(char *str) 
 { 
  cout << str << endl; 
 } 
 catch(int i) 
 { 
  cout << i << endl; 
 } 
}

也可以自己定义异常类来进行处理:


#include <iostream> 
#include <exception> 
using namespace std; 
 
//可以自己定义Exception 
class myexception: public exception 
{ 
 virtual const char* what() const throw() 
 { 
  return "My exception happened"; 
 } 
}myex; 
 
int main () { 
 try 
 {  
  if(true) //如果,则抛出异常; 
   throw myex; 
 } 
 catch (exception& e) 
 { 
  cout << e.what() << endl; 
 } 
 return 0; 
}

同时也可以使用标准异常类进行处理:


#include <iostream> 
#include <exception> 
using namespace std; 
 
int main () { 
 try 
 { 
  int* myarray= new int[100000]; 
 } 
 catch (exception& e) 
 { 
  cout << "Standard exception: " << e.what() << endl; 
 } 
 return 0; 
}

一、简单的例子

首先通过一个简单的例子来熟悉C++ 的 try/catch/throw(可根据单步调试来熟悉,try catch throw部分是如何运行的):


#include <stdlib.h>
#include "iostream"
using namespace std;

double fuc(double x, double y)      //定义函数
{
 if(y==0)
 {
  throw y;         //除数为0,抛出异常
 }
 return x/y;         //否则返回两个数的商
}

int _tmain(int argc, _TCHAR* argv[])
{
 double res;
 try           //定义异常
 {
  res=fuc(2,3);
  cout<<"The result of x/y is : "<<res<<endl;
  res=fuc(4,0);        //出现异常
 }
 catch(double)         //捕获并处理异常
 {
  cerr<<"error of dividing zero.n";
  exit(1);         //异常退出程序
 }
 return 0;
}

catch 的数据类型需要与throw出来的数据类型相匹配的。

 

二、catch(...)的作用

  catch(…)能够捕获多种数据类型的异常对象,所以它提供给程序员一种对异常对象更好的控制手段,使开发的软件系统有很好的可靠性。因此一个比较有经验的程序员通常会这样组织编写它的代码模块,如下:


void Func()
{
  try
  {
    // 这里的程序代码完成真正复杂的计算工作,这些代码在执行过程中
    // 有可能抛出DataType1、DataType2和DataType3类型的异常对象。
  }
  catch(DataType1& d1)
  {
  }
  catch(DataType2& d2)
  {
  }
  catch(DataType3& d3)
  {
  }
  /*********************************************************  注意上面try block中可能抛出的DataType1、DataType2和DataType3三
  种类型的异常对象在前面都已经有对应的catch block来处理。但为什么
  还要在最后再定义一个catch(…) block呢?这就是为了有更好的安全性和
  可靠性,避免上面的try block抛出了其它未考虑到的异常对象时导致的程
  序出现意外崩溃的严重后果,而且这在用VC开发的系统上更特别有效,因
  为catch(…)能捕获系统出现的异常,而系统异常往往令程序员头痛了,现
  在系统一般都比较复杂,而且由很多人共同开发,一不小心就会导致一个
  指针变量指向了其它非法区域,结果意外灾难不幸发生了。catch(…)为这种
  潜在的隐患提供了一种有效的补救措施。  *********************************************************/
  catch(…)
  {
  }
}