例外処理を示すC++プログラム
いくつかの深刻な複雑な数学演算を計算する関数があるとします。ただし、操作中にいくつかの例外が発生する可能性があります。発生する可能性のあるさまざまな種類の例外を処理し、次のことを実行する必要があります。
- コンピュータが計算用のメモリを割り当てることができない場合は、「MemoryLow!」を出力する必要があります
- 他のC++関連の例外が発生した場合は、「Exception:」を出力してから例外を出力する必要があります。
- 何か他のことが起こった場合、「未処理の例外」を出力します。
値のペアを含む配列が与えられ、それを関数に渡します。例外が発生した場合はそれを処理し、それ以外の場合は出力値を出力します。
例外を生成する関数のメカニズムを無視して、例外を処理するだけで済みます。
したがって、入力がarr ={{361643035132、2297873642249}、{-17、15}};の場合、出力は-
になります。Memory Low! Exception: val1 is negative
値の最初のペアは大きすぎて処理できないため、「メモリ不足」が出力されます。 2番目のペアの最初の値は負です。提供されている関数はそれを処理できないため、例外「val1 isnegative」を生成/スローします、
これを解決するには、次の手順に従います-
- iを初期化する場合:=0、i
- val1:=values [i、0]
- val2:=values [i、1]
- 試してみてください
- print(foo(val1、val2))
- メモリを割り当てることができない場合(bad_alloc例外がキャッチされた場合)、
- print( "Memory Low!")
- それ以外の場合、他の標準C ++例外eがキャッチされた場合、
- print( "例外:")
- 例外の詳細を印刷する
- それ以外の場合、他の例外がキャッチされた場合は、
- print( "未処理の例外")
例
理解を深めるために、次の実装を見てみましょう-
#include <iostream> #include <exception> #include <string> #include <stdexcept> #include <vector> #include <cmath> using namespace std; class Solution { private: static int value; public: static int foo(long long val1, long long val2) { value += 1; if(val1 < 0) { throw std::invalid_argument("val1 is negative"); } vector<int> vectorList(val1, 0); int r = -1, c = sqrt(-1); if(val2 == 0) throw 0; r = (val1 / val2) * r; int ans = vectorList.at(val2); return r + val1 - val2 * ans; } static int getVal() { return value; } }; int Solution::value = 0; void solve(int t, long int values[][2]) { for (int i = 0; i < t; i++) { long long val1, val2; val1 = values[i][0]; val2 = values[i][1]; try { cout << Solution::foo(val1, val2) << '\n'; } catch (const std::bad_alloc&) { cout << "Memory Low!\n"; } catch (const std::exception& e) { cout << "Exception: " << e.what() << '\n'; } catch (...) { cout << "Unhandled Exception\n"; } } } int main() { long int arr[][2] = {{361643035132, 2297873642249}, {-17, 15}}; solve(2, arr); }
入力
long int arr[][2] = {{361643035132, 2297873642249}, {-17, 15}}; solve(2, arr);
出力
Memory Low! Exception: val1 is negative
-
C ++プログラムでの二分探索?
二分探索は、半区間探索、対数探索、または二分探索とも呼ばれ、ソートされた配列内のターゲット値の位置を見つける検索アルゴリズムです。二分探索は、ターゲット値を配列の中央の要素と比較します。それらが等しくない場合、ターゲットが存在できない半分が削除され、残りの半分で検索が続行され、再び中央の要素がターゲット値と比較され、ターゲット値が見つかるまでこれが繰り返されます。残りの半分が空の状態で検索が終了した場合、ターゲットは配列に含まれていません。アイデアは単純ですが、バイナリ検索を正しく実装するには、特に配列の値が範囲内の整数のすべてではない場合、終了条件と中間点の計算に関する微妙な点に注意する必要
-
C++での例外処理の基本
C ++では、例外処理はランタイムエラーを処理するプロセスです。例外は、C++で実行時にスローされるイベントです。すべての例外は、std::exceptionクラスから派生します。処理可能なランタイムエラーです。例外を処理しない場合は、例外メッセージを出力してプログラムを終了します。 例外は、C ++標準では、プログラム内で使用できるクラスとして定義されています。親子クラス階層の配置を以下に示します。 C++の一般的な例外クラスは次のとおりです。 例外 説明 std ::exception これは、すべての標準C++例外の例外および親クラスです。 std ::