C ++例外処理
例外は、プログラムの実行中に発生する問題です。C ++例外は、ゼロ除算の試行など、プログラムの実行中に発生する例外的な状況への応答です。
例外は、プログラムのある部分から別の部分に制御を移す方法を提供します。C ++例外処理は、次の3つのキーワードに基づいて構築されています。try, catch, そして throw。
throw−問題が発生すると、プログラムは例外をスローします。これは、throw キーワード。
catch−プログラムは、問題を処理したいプログラム内の場所で例外ハンドラーを使用して例外をキャッチします。ザ・catch キーワードは、例外のキャッチを示します。
try − a tryblockは、特定の例外がアクティブ化されるコードのブロックを識別します。その後に1つ以上のキャッチブロックが続きます。
ブロックが例外を発生させると仮定すると、メソッドは、との組み合わせを使用して例外をキャッチします。 try そして catchキーワード。例外を生成する可能性のあるコードの周囲にtry / catchブロックが配置されます。try / catchブロック内のコードは保護されたコードと呼ばれ、try / catchを使用するための構文は次のとおりです。
try {
// protected code
} catch( ExceptionName e1 ) {
// catch block
} catch( ExceptionName e2 ) {
// catch block
} catch( ExceptionName eN ) {
// catch block
}
複数のリストを作成できます catch さまざまなタイプの例外をキャッチするステートメント try ブロックは、さまざまな状況で複数の例外を発生させます。
例外のスロー
例外は、を使用してコードブロック内のどこにでもスローできます。 throwステートメント。throwステートメントのオペランドは、例外のタイプを決定し、任意の式にすることができ、式の結果のタイプによって、スローされる例外のタイプが決まります。
以下は、ゼロ除算条件が発生したときに例外をスローする例です。
double division(int a, int b) {
if( b == 0 ) {
throw "Division by zero condition!";
}
return (a/b);
}
例外をキャッチする
ザ・ catch 次のブロック tryブロックは例外をキャッチします。キャッチする例外のタイプを指定できます。これは、キーワードcatchに続く括弧内に表示される例外宣言によって決定されます。
try {
// protected code
} catch( ExceptionName e ) {
// code to handle ExceptionName exception
}
上記のコードは例外をキャッチします ExceptionNameタイプ。catchブロックがtryブロックでスローされるすべてのタイプの例外を処理するように指定する場合は、次のように、例外宣言を囲む括弧の間に省略記号...を付ける必要があります。
try {
// protected code
} catch(...) {
// code to handle any exception
}
以下は、ゼロ除算例外をスローし、それをcatchブロックでキャッチする例です。
#include <iostream>
using namespace std;
double division(int a, int b) {
if( b == 0 ) {
throw "Division by zero condition!";
}
return (a/b);
}
int main () {
int x = 50;
int y = 0;
double z = 0;
try {
z = division(x, y);
cout << z << endl;
} catch (const char* msg) {
cerr << msg << endl;
}
return 0;
}
タイプの例外を発生させているため const char*したがって、この例外をキャッチしている間、catchブロックでconst char *を使用する必要があります。上記のコードをコンパイルして実行すると、次の結果が生成されます-
Division by zero condition!
C ++の標準例外
C ++は、で定義されている標準例外のリストを提供します。 <exception>プログラムで使用できます。これらは、以下に示す親子クラス階層に配置されます-
上記の階層で言及されている各例外の簡単な説明は次のとおりです-
シニア番号 | 例外と説明 |
---|---|
1 | std::exception すべての標準C ++例外の例外および親クラス。 |
2 | std::bad_alloc これはによって投げることができます new。 |
3 | std::bad_cast これはによって投げることができます dynamic_cast。 |
4 | std::bad_exception これは、C ++プログラムで予期しない例外を処理するのに便利なデバイスです。 |
5 | std::bad_typeid これはによって投げることができます typeid。 |
6 | std::logic_error コードを読み取ることで理論的に検出できる例外。 |
7 | std::domain_error これは、数学的に無効なドメインが使用された場合にスローされる例外です。 |
8 | std::invalid_argument これは、無効な引数が原因でスローされます。 |
9 | std::length_error これは、大きすぎるstd :: stringが作成されたときにスローされます。 |
10 | std::out_of_range これは、「at」メソッドによってスローできます。たとえば、std :: vectorやstd :: bitset <> :: operator []()などです。 |
11 | std::runtime_error コードを読み取っても理論的には検出できない例外。 |
12 | std::overflow_error これは、数学的なオーバーフローが発生した場合にスローされます。 |
13 | std::range_error これは、範囲外の値を保存しようとしたときに発生します。 |
14 | std::underflow_error これは、数学的アンダーフローが発生した場合にスローされます。 |
新しい例外を定義する
継承してオーバーライドすることで、独自の例外を定義できます exceptionクラスの機能。以下は、std :: exceptionクラスを使用して、標準的な方法で独自の例外を実装する方法を示す例です。
#include <iostream>
#include <exception>
using namespace std;
struct MyException : public exception {
const char * what () const throw () {
return "C++ Exception";
}
};
int main() {
try {
throw MyException();
} catch(MyException& e) {
std::cout << "MyException caught" << std::endl;
std::cout << e.what() << std::endl;
} catch(std::exception& e) {
//Other errors
}
}
これにより、次の結果が生成されます-
MyException caught
C++ Exception
ここに、 what()は例外クラスによって提供されるパブリックメソッドであり、すべての子例外クラスによってオーバーライドされています。これにより、例外の原因が返されます。