클래스는 크게 일반 클래스와 추상 클래스로 나뉘는데 추상 클래스는 클래스 내 '추상 메소드'가 하나 이상 포함되거나 abstract로 정의된 경우를 말합니다. 반면
인터페이스는 모든 메소드가 추상메소드인 경우입니다.
추상클래스와 인터페이스는 상속받는 클래스 혹은 구현하는 인터페이스 안에 있는 추상메소드를 구현하도록 강제한다.
추상클래스와 인터페이스는 존재 목적이 다릅니다.
추상클래스는 그 추상 클래스를 상속받아서 기능을 이용하고, 확장시키는데 있습니다.
반면에 인터페이스는 함수의 껍데기만 있는데, 그 이유는 그 함수의 구현을 강제하기 위해서입니다. 구현을 강제함으로써 구현 객체의 동작을 보장할 수 있습니다.
상속은 슈퍼클래스의 기능을 이용하거나 확장하기 위해서 사용되고, 다중 상속의 모호성 때문에 하나만 상속받을 수 있습니다.
반면 인터페이스는 해당 인터페이스를 구현한 객체들에 대해서 동일한 동작을 약속하기 위해 존재합니다.
1. 공통점
abstract class(추상 클래스)와 interface 는 선언만 있고 구현 내용이 없는 클래스이다.
그래서 자기 자신이 new를 해서 객체를 생성할 수 없으며,
추상클래스를 extends 받거나, interface를 implements 한 자식만이 객체를 생성할 수 있다.
상속받은 자식이 구현을 반드시 하도록 해야할 때 사용한다.
JAVA에서는 type이 지정되있기 때문에 선언된 type과 자식의 type이 같아야만 한다.
2. 차이점
추상클래스는 말그대로 클래스이고, interface는 구현하기 전에 메소드에 대해 명세된 것이랄까?
그래서 상속을 받음에도 불구하고 클래스에선 상속이라고 쓰지만 interface는 implemets(구현) 이라고 쓴다.
추상클래스의 정의는 abstract 메소드가 하나라도 존재하는 클래스를 일컫는다.
때문에 일부는 구현된 메소드도 있고, abstract라고 붙어있는 메소드는 구현이 안되어있다.
추상클래스를 상속받는 클래스는 반드시 추상메소드를 구현해야한다.
그래서 필수적으로 구현해야할 메소드가 있을 때 추상클래스를 쓰게된다.
인터페이스는 구현체 없이, 메소드에 대한 명세만 되어있다.
인터페이스를 상속받는 클래스에서는 반드시 인터페이스에 있는 메소드를 다 구현해야한다.
자바는 단일상속을 지원하기 때문에 추상클래스는 단일상속이지만,
interface를 사용하게 되면, implements를 구현하는 부분에서 extends 또한 사용할 수 있다.
즉, 다중상속이 가능해진다.
'이러이러한 메소드를 쓸 것이다.' 인터페이스에 선언을 해놓고, 가져다가 반드시 선언된 그대로 모두 구현하면 되는게 인터페이스이고,
이러이러한 메소드가 있지만 가져다 쓰거나 오버라이드 하거나, abstract가 붙은 메소드는 반드시 구현하면 되는게 abstract class이다.
3. 용도
책을 아무리 읽고 인터넷을 찾아봐도 이해가 잘 안가는
추상클래스와 인터페이스의 용도!
그나마 조금 알게된 용도를 정리한다 ㅎㅎ
인터페이스를 설명하려면 다형성(Polymorphism)에 대한 개념이 등장한다.
다형성이라고 하면 어려울 것 같지만 아래같이 생각하면 쉬울 것이다.
interface : 동물 method : 먹는다, 걷는다, 잔다 구현체(implement) : 고양이, 원숭이, 병아리 |
동물들은 모두 먹고, 걷는다.
하지만 동물들마다 먹고 걷는 방식은 다르다.
구현체에서는 동물 각각이 먹고 걷는 방식을 구현한다.
같은 '먹는다'라는 동사에서, 동물마다 여러가지 형태로 구현할 수 있기때문에 이름이 다형성.
그렇다면 인터페이스를 쓰면 얻는 이득이 무엇인가?
동물이 먹고, 걷고, 자는 것은 공통적인데, 그 것을 행하는 방법이 각자 다르다.
고양이는 걸을 때 네발로 걷고, 원숭이는 두발 또는 네발로, 병아리도 두발로..
그래서 동물이 먹고, 걷고, 잔다는 틀만 만들어놓고
고양이, 원숭이, 병아리는 그 틀안에 자신만의 방법으로 메소드를 구현하는 것이다.
반드시 구현체 동물들은 먹고 걷고 자는방법이 구현되어야 한다. 동물이라면..
그리고 고양이의 자는법이 달라져도 원숭이, 병아리에게는 아무 영향도 없다.
그럼 추상화 클래스는 언제 쓰는게 좋은가?
야생고양이가 새끼를 낳았다.
새끼는 인간에 의해 집고양이가 되었다고하자.
어미고양이(부모클래스) - 야생고양이 - 자는법 (메소드) - 집에서 사는법 (추상화 메소드)
- 자는법 (메소드) - 집에서 사는법 (메소드) |
좀 억지이지만 ㅋㅋㅋ
어미고양이는 야생고양이므로,
집에서 사는법은 모르지만, 새끼고양이는 집에서 사는법을 알려주기 위해 추상화 메소드로 만들었다.(구현X)
어미고양이는 자는법이 있었고, 자식에게 전수하였다.
그러나 자식은 집고양이라 어미고양이와 자는법이 달랐다.
그래서 자식고양이 나름대로 자는법을 새로 터득하였다.
그게 이미 구현되어있는 부모클래스의 내용을 Override를 하는 것이다.
새끼고양이는 집 생활을 하며, 어미고양이가 모르는, 집에 사는법을 더 많이 터득하였다.
(부모 클래스보다 더 많이 구현되는 경우가 대부분이다)
그니깐 총정리를 하면,
인터페이스는 다형성이라 생각하면되고,
상속은 부모 - 자식 관계..
부모가 갖고있는 기능을 유전 받으면서, 기능을 더 추가한다거나,
부모의 유전된 기능을 약간 수정할 때 쓴다.
출처: http://marobiana.tistory.com/58 [Take Action]
반응형