C ++の構文要素は、tryキャッチ例外処理を建て... ...
-t Ryは通常のコードのロジック文の処理
- catchステートメントハンドルの例外
に対応するcatch文処理による-try例外声明
試します
{
ダブル R =分割(1、0 );
}
キャッチ(...)
{
裁判所未満 << " ゼロで分割... " << てendl;
}
C ++例外がthrowステートメント情報によってスローされます
二重分割(ダブル A、ダブルB)
{
constの ダブルデルタ= 0.000000000000001 。
ダブル RET = 0 ;
もし(((! -デルタ<B)&&(B < デルタ)))
{
RET = A / B。
}
他
{
スロー 0 ; // 生じる他の異常0
}
戻る権利を。
}
分析取り扱いC ++例外
スローされた例外が-throw catchハンドラでなければならない現在の関数が例外を処理することができますが、プログラムは継続して例外を処理することはできません現在の関数を、関数が実行してリターンを停止します
未処理の例外は、そうでない場合は、プログラムが実行を停止し、治療を受けるまでの関数呼び出しスタックに沿って上向きに伝播します
異常が発生した場合、見た目の関数3は、この場合、無処理能力では、この機能を処理する能力を持っています。だから、関数3この機能は、すぐに実行を停止し、と
例外復帰治療を買う余裕ができない場合はfunction2にはfunction2ポイントを呼び出し、直ちに停止、および関数1でその呼び出しサイトに例外が戻るとします。
書式#include <iostreamの>
の#include < 文字列 >
使用して 名前空間はstdを、
二重分割(ダブル A、ダブルB)
{
const double delta = 0.000000000000001;
double ret = 0;
if( !((-delta < b) && (b < delta)) )
{
ret = a / b;
}
else
{
throw 0;
}
return ret;
}
int main(int argc, char *argv[])
{
try
{
double r = divide(1, 0);
cout << "r = " << r << endl;
}
catch(...)
{
cout << "Divided by zero..." << endl;
}
return 0;
}
同一个try语句可以跟上多个catch语句
-catch语句可以定义具体处理的异常类型
-不同类型的异常由不同的catch语句具体负责
-try语句中可以抛出任何类型的异常
-catch(...)用于处理所有类型的异常
-任何异常都只能被捕获(catch)一次
异常类型匹配
#include <iostream>
#include <string>
using namespace std;
void Demo1()
{
try
{
throw 'c';
}
catch(char c)
{
cout << "catch(char c)" << endl;
}
catch(short c)
{
cout << "catch(short c)" << endl;
}
catch(double c)
{
cout << "catch(double c)" << endl;
}
catch(...)
{
cout << "catch(...)" << endl;
}
}
void Demo2()
{
throw string("D.T.Software");
}
int main(int argc, char *argv[])
{
Demo1();
try
{
Demo2();
}
catch(char* s)
{
cout << "catch(char *s)" << endl;
}
catch(const char* cs)
{
cout << "catch(const char *cs)" << endl;
}
catch(string ss)
{
cout << "catch(string ss)" << endl;
}
return 0;
}
小结:
C++中直接支持异常处理的概念
try...catch...是C++中异常处理的专用语句
try语句处理正常代码逻辑,catch语句处理异常情况
同一个try语句可以跟上多个catch语句
异常处理必须严格匹配,不进行任何的类型转换