추상(abstract) 클래스가 필요한 기본적인 이유

개발을 공부하기 시작한지 얼마 안되어 학습한 내용이었기 때문에 적당한 수준으로 이해하고 넘어갔던 것이다.
찝찝한 상태로 남아있는 개념들을 하나씩 바로 잡을 계획이었는데, 추상클래스에 대해 조금 더 이해 할 기회가 생겨 정리해본다.


Java의 정석에서는 추상클래스와 추상메서드가 필요한 이유를 명확하게 설명하지 않았다.

때문에 나는 지금까지 추상클래스(메서드)가 필요한 이유를
자손 클래스에서 추상메서드를 반드시 구현하도록 강요하기 위해서라고만 이해하고 있었다.
그리고 아직 실무에서 추상클래스(메서드)를 작성할 일이 없었기 때문에 발전이 없는 상태였다.

하지만 Java로 배우는 자료구조 강의에서는 조금 다르게 설명했고, 난 이 예제와 설명이 더 와닿았다.

 

예제를 단순화 해보면,

  1. Event 라는 부모클래스가 있고,

    public class Event {
        ...
    }
  2. Event를 상속받은 자식클래스 aEvent, bEvent, cEvent가 있으며, 각각 isRelevant() 메서드를 구현하였다.

    public class aEvent extends Event {
        ...
        public boolean isRelevant(Data data) {
            return logic.a;
        }
    }
    public class bEvent extends Event {
        ...
        public boolean isRelevant(Data data) {
            return logic.b;
        }
    }
    public class cEvent extends Event {
        ...
        public boolean isRelevant(Data data) {
            return logic.c;
        }
    }
  3. 그리고 다른 클래스의 어느 메서드에서 Event 타입으로 선언된 배열 events[]의 각 원소를 isRelevant()메소드로 검증하는 로직을 작성했다. (events[] 배열의 각 원소는 aEvent, bEvent, cEvent 타입의 원소들이다.)

    public class someClass() {
        ...
        Event events[] = new Event[100];
        ...
            
        public void someMethod() {
            for(int i=0; i<n; i++)
                if(events[i].isRelevant(someData)) // 컴파일 에러!!!
                    system.out.println( events[i].toString());
        }

    그런데 isRelevant()메소드에서 컴파일 에러가 발생한다.
    왜냐하면 events[] 배열은 Event 타입으로 선언되었는데, Event 클래스에는 isRelevant() 메서드가 정의되어 있지 않기 때문이다.

    배열의 각 원소가 Event 클래스를 상속받은 클래스의 객체이고, 각 클래스는 isRelevant() 메서드가 구현되어 있지만,
    컴파일러는 Event 클래스에 isRelevant() 메서드가 없는 것을 허용하지 않는 것이다.

    경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
    어린이용이며, 설치가 필요없는 브라우저 게임입니다.
    https://s1004games.com

    (events[i].toString()에서 컴파일 에러가 나지 않는 이유는 toString() 메서드는 모든 클래스의 조상 클래스인 Object 클래스에 정의된 메서드이기 때문이다.)

  4. 이 때, 단순히 컴파일 에러만 피하고자 한다면,
    아래와 같이 Event 객체에 사용될 일 없는 isRelevant() 메서드를 정의할 수 있을 것이다.

    public class Event {
        ...
    
        public boolean isRelevant(Data data) {
            return false;
        }
    }

    위와 같이 메서드를 정의하면 컴파일 에러는 사라지고 정상적으로 동작한다.
    하지만 사용되지 않을 메서드를 구현하는 것은 올바른 해결책이 아니다.

  5. 이 문제를 해결하려면 isRelevant()메서드를 추상 메서드로 만들면 된다.
    (그리고 아래 코드와 같이 추상 메서드가 하나라도 있으면 그 클래스는 추상 클래스가 된다.)

    public abstract class Event {
        ...
    
        public abstract boolean isRelevant(Data data);
    }


이 예제가 이해하기 쉬웠던 이유는 나같은 초보자가 코드를 짜면서 맞이하는 상황과 비슷한 흐름이기 때문이다.
나의 경우에는, 큰 그림을 보지 못하고 우선 동작하는 코드를 작성한다.
그러다 보면 코드 중복이 발견되고, 그 중복을 해결하기 위해 그제서야 추상화와 상속을 고민한다.

때문에 부모클래스에 추상 메서드를 선언하여 추상클래스로 만들고, 그 클래스를 상속받은 서브클래스들에서 추상메서드를 구현하는 방식으로 설명하는 Java의 정석의 예제는 초보개발자 입장에서 제대로 이해할 수 없었던 것이다.

물론 추상 메서드와 추상 클래스의 역할과 활용에 대해서는 더 깊은 이야기들이 있겠지만,
실무에서 마주하게 되길 바라면서 우선은 이 정도로 정리해본다.

[출처] https://ryan-han.com/post/java/abstract_class/

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
78 [Java 일반] 07-06 함수형 프로그래밍 졸리운_곰 2023.09.04 6
77 [Java 일반] [JAVA] JAVA의 람다식 사용법 및 다양한 작성 예제 file 졸리운_곰 2023.09.04 39
76 [Java 언어] [Java] 람다식(Lambda Expressions) 사용법 및 예제 졸리운_곰 2023.09.04 22
75 [Java][jupyter notebook][!java] 주피터 노트북에서 자바 실행 환경구축. java on jupyter notebook file 졸리운_곰 2023.08.24 24
74 [java maven] jar 파일 의존성 한번에 다운로드 maven 사용 졸리운_곰 2023.08.18 33
73 [Java] 효율적인 JUnit 사용 방법과 유용한 팁 file 졸리운_곰 2022.10.20 32
72 [Java] Java Console Input and Output Examples 졸리운_곰 2021.11.07 22
71 [Java] \ 문자 빠구기 : replaceAll 사용시 특수문자 졸리운_곰 2021.07.13 37
70 이클립스에서 java 버전 변경 file 졸리운_곰 2021.04.29 33
69 JAVA) 예외처리(throw , throws) file 졸리운_곰 2021.01.24 21
68 예외처리 (throwable, exception, error, throws) file 졸리운_곰 2021.01.21 39
67 [Java] 자바 extends, implements 차이 file 졸리운_곰 2020.12.10 48
66 Maven 배포시 Local Jar 파일과 함께 하기! file 졸리운_곰 2020.10.06 16
65 How to add a local lib directory to Maven 졸리운_곰 2020.10.06 17
64 [Maven] 외부 jar 의존성 추가, war build 시 외부 jar 포함시키기 졸리운_곰 2020.10.05 239
63 Spring Boot 프로젝트에 외부 라이브러리(jar) 추가하기 졸리운_곰 2020.10.05 695
62 [maven 설정] Jackson Databind » 2.6.7.1 졸리운_곰 2020.10.05 33
61 [maven 설정] MongoDB Java Driver » 3.12.6 졸리운_곰 2020.10.05 18
60 Maven 에 직접 jar 라이브러리 추가하기!!! ( 외부 repository 사용이 안될때) + scope 정리 졸리운_곰 2020.10.05 20
» 추상(abstract) 클래스가 필요한 기본적인 이유 졸리운_곰 2019.10.30 68
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED