이번에는 좀 더 다양한 예외 상황을 처리하는 방법을 알아보자. 코드를 보자.

 

package org.opentutorials.javatutorials.exception;
 
class A{
    private int[] arr = new int[3];
    A(){
        arr[0]=0;
        arr[1]=10;
        arr[2]=20;
    }
    public void z(int first, int second){
        System.out.println(arr[first] / arr[second]);
    }
}
 
public class ExceptionDemo1 {
    public static void main(String[] args) {
        A a = new A();
        a.z(10, 1);
    }
}

 

위의 결과는 아래와 같다.

 

 

이유를 따져보자. 배열 arr은 3개의 값을 담을 수 있다.

 

private int[] arr = new int[3];

 

하지만 10번째 인덱스를 호출하고 있다.

 

a.z(10, 1);
System.out.println(arr[first] / arr[second]);

 

따라서 존재하지 않는 값을 가져오려고 시도하고 있기 때문에 자바에서는 ArrayIndexOutOfBoundsException을 발생시킨 것이다.

위의 코드를 조금 변경해보자.


package org.opentutorials.javatutorials.exception;
 
class A{
    private int[] arr = new int[3];
    A(){
        arr[0]=0;
        arr[1]=10;
        arr[2]=20;
    }
    public void z(int first, int second){
        System.out.println(arr[first] / arr[second]);
    }
}
 
public class ExceptionDemo1 {
    public static void main(String[] args) {
        A a = new A();
        a.z(1, 0);
    }
}

 

차이점은 아래와 같다.

 

 

결과는 아래와 같다.

 

 

위의 코드는 메소드 z 내부적으로 10/0을 실행하게 된다.

0으로 나누는 것은 불가능하기 때문에 자바는 ArithmeticException을 발생시킨다.


 

그냥 catch (Exception e) { e.printStackTrace(); }

로 처리하면 

모든 에러를 포괄하는 메시지로 처리된다.


위의 예제를 통해서 보여주고 싶은 것은 같은 로직이지만 상황에 따라서 다른 예외가 발생할 수 있다는 것이다.

이런 경우는 어떻게 예외를 처리해야 할까? 예외 처리를 추가한 아래의 예제를 보자.

 

package org.opentutorials.javatutorials.exception;
 
class A{
    private int[] arr = new int[3];
    A(){
        arr[0]=0;
        arr[1]=10;
        arr[2]=20;
    }
    public void z(int first, int second){
        try {
            System.out.println(arr[first] / arr[second]);
        } catch(ArrayIndexOutOfBoundsException e){
            System.out.println("ArrayIndexOutOfBoundsException");
        } catch(ArithmeticException e){
            System.out.println("ArithmeticException");
        } catch(Exception e){
            System.out.println("Exception");
        }
         
    }
}
 
public class ExceptionDemo1 {
    public static void main(String[] args) {
        A a = new A();
        a.z(10, 0);
        a.z(1, 0);
        a.z(2, 1);
    }
}

 

아래는 차이점이다.

 

 

결과는 다음과 같다.

 

 

예제는 다중 catch를 보여준다.

조건문의 else if처럼 여러 개의 catch를 하나의 try 구문에서 사용할 수 있다.

이를 통해서 보다 간편하게 다양한 상황에 대응할 수 있다.

위의 코드는 try 구문에서 예외가 발생했을 때 그 예외의 종류가 ArrayIndexOutOfBoundsException이라면 14행이 실행되고, ArithemeticException이라면 16행이 실행되고 그 외의 것이라면 18행이 실행된다는 의미다.

 

만약 아래와 같이 메소드 z의 코드를 변경한다면 어떻게 될까?

 

 

아래와 같은 메시지가 출력되면서 컴파일 조차 되지 않을 것이다.

 

 

 그것은 Exception이 ArrayIndexOutOfBoundsException, ArithemeticException 보다 포괄적인 예외를 의미하기 때문에 Exception 이후에 등장하는 catch 문은 실행될 수 없는 구문이기 때문이다. 자바 컴파일러가 불필요한 로직을 감지하고 이를 개발자에게 알려주는 것이다.

'📌 java > java' 카테고리의 다른 글

java - 예외의 강제  (0) 2020.04.28
java - finally  (0) 2020.04.28
java - exception 발생에 대한 처리  (0) 2020.04.28
java - try, catch  (0) 2020.04.10
java - 다형성  (0) 2020.04.04
복사했습니다!