[바로실습] 생활코딩 - 자바(JAVA)
    • 01
      언어 소개
    • 언어 소개
    • 02
      숫자와 문자
    • 숫자
      문자와 문자열
    • 03
      변수
    • 변수의 선언과 할당
      정수와 실수
      문자열
      변수의 효용
    • 04
      주석과 세미콜론
    • 주석과 세미콜론
      주석과 세미콜론 - Quiz
    • 05
      데이터 타입
    • 데이터의 크기
      데이터 타입의 종류
    • 06
      상수의 데이터 타입
    • 상수의 데이터 타입
    • 07
      형 변환
    • 형 변환
      명시적 형 변환
    • 08
      연산자
    • 산술 연산자
      형변환
      단항 연산자
      연산의 우선순위
    • 09
      비교와 Boolean
    • 비교와 Boolean
    • 10
      조건문
    • if
      else
      변수와 비교연산자 그리고 조건문
      조건문의 중첩
      switch 문
    • 11
      논리 연산자
    • AND ( && )
      OR ( || )
      NOT ( ! )
    • 12
      반복문
    • while
      for
      반복문이 없다면
      반복문의 제어
      반복문의 중첩
    • 13
      배열
    • 배열
      배열의 개념
      제어
      배열의 사용
      for-each
      오류
    • 14
      메소드
    • 메소드
      메소드의 정의와 호출
      메소드가 없다면
      입력값
      return
    • 15
      입력과 출력
    • 입력과 출력
      앱이 시작할 때 데이터를 입력
      앱이 실행중에 데이터를 입력
      여러 형태의 입출력
    • 16
      객체 지향 프로그래밍
    • 객체 지향 프로그래밍
      추상화
      부품화
    • 17
      클래스와 인스턴스 그리고 객체
    • 클래스와 인스턴스 이전의 프로그래밍
      객체화1
      객체화2
      객체화3
    • 18
      클래스 맴버와 인스턴스 맴버
    • 맴버
      클래스 변수
      클래스 메소드
      맴버타입의 비교
    • 19
      유효범위
    • 유효범위
      전역변수와 지역변수
      다양한 유효범위들
      인스턴스의 유효범위
    • 20
      초기화와 생성자
    • 초기화와 생성자
    • 21
      상속
    • 상속의 개념
      코드로 알아보는 상속
      다양한 종류의 상속
    • 22
      상속과 생성자
    • 기본 생성자
      super
    • 23
      overriding
    • overriding1
      overriding2
    • 24
      overloading
    • overloading1
      overloading2
    • 25
      클래스 패스
    • 컴파일과 클래스
      클래스의 경로
      환경변수
    • 26
      패키지
    • 패키지의 개념
      패키지의 사용
      손 컴파일
      중복의 회피
    • 27
      API와 API 문서 보는 법
    • API와 API 문서1
      API와 API 문서2
    • 28
      접근 제어자
    • 접근 제어자
      자유와 규제
      접근 제어자를 사용하는 이유
      세밀한 제어
      클래스의 접근 제어자
    • 29
      abstract
    • 문법
      추상클래스를 사용하는 이유
      디자인 패턴
    • 30
      final
    • final
    • 31
      인터페이스
    • 문법과 개념
      사용하는 이유
      규칙들
    • 32
      다형성
    • 메소드와 다형성
      클래스와 다형성1
      클래스와 다형성2
      실전 예제
      인터페이스와 다형성1
      인터페이스와 다형성2
    • 33
      예외1 - 문법
    • 성공과 실패
      예외란?
      뒷수습의 방법
      다양한 예외들
      finally
    • 34
      예외2 - 예외 던지기
    • 예외의 강제
      throw와 throws
      책임의 전가 throws
    • 35
      예외3 - 만들기
    • 예외 만들기
      예외의 여러가지 상황들
      예외의 선조 - Throwable
      나만의 예외 만들기
    • 36
      Object 클래스
    • 상속
      toString
      equals
      finalize
      clone
    • 37
      상수와 enum
    • 상수에 대한 복습
      enum의 배경
      enum의 문법
      enum과 생성자
    • 38
      참조
    • 복제
      참조
      참조와 복제
      메소드와 참조
    • 39
      제네릭
    • 제네릭의 사용
      제네릭을 사용하는 이유
      제네릭의 특성
      제네릭의 생략
      제네릭의 제한
    • 40
      Collections Framework
    • ArrayList의 사용법
      전체적인 구성
      List와 Set의 차이점
      Set
      Map
      정렬
    책임의 전가 throws
    배우기
    34 예외2 - 예외 던지기
    책임의 전가 throws


    package org.opentutorials.javatutorials.exception;
    import java.io.*;
    class B{
        void run(){
            BufferedReader bReader = null;
            String input = null;
            try {
                bReader = new BufferedReader(new FileReader("out.txt"));
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            }
            try{
                input = bReader.readLine();
            } catch (IOException e){
                e.printStackTrace();
            }       
            System.out.println(input); 
        }
    }
    class C{
        void run(){
            B b = new B();
            b.run();
        }
    }
    public class ThrowExceptionDemo {
        public static void main(String[] args) {
             C c = new C();
             c.run();
        }   
    }

    차이점

    위의 코드는 B.run이 FileReader의 생성자와 BufferedReader.readLine가 던진 예외를 try...catch로 처리한다. 즉 B.run이 예외에 대한 책임을 지고 있다.

    그런데 B.run이 예외 처리를 직접 하지 않고 다음 사용자 C.run에게 넘길 수 있다. 아래의 코드를 보자.

    package org.opentutorials.javatutorials.exception;
    import java.io.*;
    class B{
        void run() throws IOException, FileNotFoundException{
            BufferedReader bReader = null;
            String input = null;
            bReader = new BufferedReader(new FileReader("out.txt"));
            input = bReader.readLine();
            System.out.println(input); 
        }
    }
    class C{
        void run(){
            B b = new B();
            b.run();
        }
    }
    public class ThrowExceptionDemo {
        public static void main(String[] args) {
             C c = new C();
             c.run();
        }   
    }

    주목할 차이점은 아래와 같다.

    B 내부의 try...catch 구문은 제거되었고 run 옆에 throws IOException, FileNotFoundException이 추가되었다. 이것은 B.run 내부에서 IOException, FileNotFoundException에 해당하는 예외가 발생하면 이에 대한 처리를 B.run의 사용자에게 위임하는 것이다. 위의 코드에서 B.run의 사용자는 C.run이다. 따라서 C.run은 아래와 같이 수정돼야 한다.

    package org.opentutorials.javatutorials.exception;
    import java.io.*;
    class B{
        void run() throws IOException, FileNotFoundException{
            BufferedReader bReader = null;
            String input = null;
            bReader = new BufferedReader(new FileReader("out.txt"));
            input = bReader.readLine();
            System.out.println(input);
        }
    }
    class C{
        void run(){
            B b = new B();
            try {
                b.run();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
    public class ThrowExceptionDemo {
        public static void main(String[] args) {
             C c = new C();
             c.run();
        }   
    }

    차이점은 아래와 같다.

    이 책임을 다시 main에게 넘겨보자.

    package org.opentutorials.javatutorials.exception;
    import java.io.*;
    class B{
        void run() throws IOException, FileNotFoundException{
            BufferedReader bReader = null;
            String input = null;
            bReader = new BufferedReader(new FileReader("out.txt"));
            input = bReader.readLine();
            System.out.println(input);
        }
    }
    class C{
        void run() throws IOException, FileNotFoundException{
            B b = new B();
            b.run();
        }
    }
    public class ThrowExceptionDemo {
        public static void main(String[] args) {
             C c = new C();
             try {
                c.run();
            } catch (FileNotFoundException e) {
                System.out.println("out.txt 파일은 설정 파일 입니다. 이 파일이 프로잭트 루트 디렉토리에 존재해야 합니다.");
            } catch (IOException e) {
                e.printStackTrace();
            }
        }   
    }

    차이점은 아래와 같다.

    out.txt 파일을 찾을 수 없는 상황은 B.run 입장에서는 어떻게 할 수 있는 일이 아니다. 엔드유저인 애플리케이션의 사용자가 out.txt 파일을 루트 디렉토리에 위치시켜야 하는 문제이기 때문에 애플리케이션의 진입점인 메소드 main으로 책임을 넘기고 있다.

    예외 처리는 귀찮은 일이다. 그래서 예외를 다음 사용자에게 전가(throw)하거나 try...catch로 감싸고 아무것도 하지 않고 싶은 유혹에 빠지기 쉽다. 하지만 예외는 API를 사용하면서 발생할 수 있는 잠재적 위협에 대한 API 개발자의 강력한 암시다. 이 암시를 무시해서는 안 된다. 물론 더욱 고민스러운 것은 예외 처리 방법에 정답이 없다는 것이겠지만 말이다.

    실습 내용

    실행결과

    out.txt   .       .


    이 예제는 out.txt 파일을 찾을 수 없는 경우의 예외처리를 하는 예제이다.

    질문하기