심각한 복잡한 수학 연산을 계산하는 함수가 있다고 가정합니다. 그러나 작업 중에 일부 예외가 발생할 수 있습니다. 발생할 수 있는 다양한 유형의 예외를 처리하고 다음을 수행해야 합니다.
- 컴퓨터가 계산을 위해 메모리를 할당할 수 없으면 'Memory Low!'를 인쇄해야 합니다.
- 다른 C++ 관련 예외가 발생하면 'Exception:'을 출력한 다음 예외를 출력해야 합니다.
- 다른 문제가 발생하면 '처리되지 않은 예외'를 출력합니다.
한 쌍의 값을 포함하는 배열이 주어지고 이를 함수에 전달합니다. 예외가 발생하면 처리하거나 그렇지 않으면 출력 값을 인쇄합니다.
예외를 생성하는 함수의 메커니즘을 무시하고 예외만 처리하면 됩니다.
따라서 입력이 arr ={{361643035132, 2297873642249}, {-17, 15}};와 같으면 출력은 -
가 됩니다.Memory Low! Exception: val1 is negative
첫 번째 값 쌍이 너무 커서 처리할 수 없으므로 '메모리 부족'이 인쇄됩니다. 두 번째 쌍의 첫 번째 값은 음수입니다. 제공된 함수는 이에 대해 작동하지 않으므로 'val1은 음수입니다'라는 예외를 생성/던집니다.
이 문제를 해결하기 위해 다음 단계를 따릅니다. −
- 초기화 i의 경우:=0, i
- val1 :=값[i, 0]
- val2 :=값[i, 1]
- 시도하다,
- 인쇄(foo(val1, val2))
- 메모리를 할당할 수 없는 경우(bad_alloc 예외가 포착됨),
- print("메모리 부족!")
- 그렇지 않으면 다른 표준 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