103 「例外修羅道」 Step09 問題

問題

あなたは、例外が発生したときに、その原因を詳細に調査できるようにログ出力する処理を作成しようとしています。

次の仕様に従って、例外が発生した際に、以下の情報を出力してください:

  1. "エラーが発生しました"(固定メッセージ)
  2. e.getMessage() による例外メッセージ
  3. e.printStackTrace() によるスタックトレース(開発者向けログ)

要件

  • メソッド名は traceError(int[] array, int index, int divisor) とする
  • 配列の要素を取り出し、それを指定された数値で割る
  • インデックスが範囲外、またはゼロ除算が起こりうる
  • 例外が発生した場合、以下の3つを出力すること:
    • "エラーが発生しました"
    • 例外のメッセージ(e.getMessage()
    • 例外のスタックトレース(e.printStackTrace()

テストコード(Main.java)

public class Main {
  public static void main(String[] args) {
    int[] data = {10, 20, 30};
    ExceptionUtil.traceError(data, 1, 5);   // 正常
    ExceptionUtil.traceError(data, 5, 2);   // インデックス範囲外
    ExceptionUtil.traceError(data, 0, 0);   // ゼロ除算
  }
}

ヒント

  • e.getMessage() は例外の簡潔な説明文(1行)を取得する
  • e.printStackTrace() は例外の発生箇所を詳細に出力する(開発用)
  • 本番環境では printStackTrace() の代わりにロガー出力が使われることが多い

解答例

103 ステップアップ問題 「例外修羅道」