1. 상속(inheritance) 이란?
- 클래스에서 상속이란, 물려주는 클래스(Parent Class, Super class)의 내용(속성과 메소드)을 물려받는 클래스(Child class, sub class)가 가지게 되는 것입니다.
- 예를 들면 국가라는 클래스가 있고, 그것을 상속받은 한국, 일본, 중국, 미국 등의 클래스를 만들 수 있으며, 국가라는 클래스의 기본적인 속성으로 인구라는 속성을 만들었다면, 상속 받은 한국, 일본, 중국 등등의 클래스에서 부모 클래스의 속성과 메소드를 사용할 수 있음을 말합니다.
- 기본적인 사용방법은 아래와 같습니다.
- 자식클래스를 선언할때 소괄호로 부모클래스를 포함시킵니다.
- 그러면 자식클래스에서는 부모클래스의 속성과 메소드는 기재하지 않아도 포함이 됩니다.
class 부모클래스:
...내용...
class 자식클래스(부모클래스):
...내용...
2. 상속 사용해보기
- 상속을 표현해보기위헤 에디터에서
inheritance.py
파일을 하나 만듭니다. - 아래와 같이 코드를 작성해봅니다.
class Country:
"""Super Class"""
name = '국가명'
population = '인구'
capital = '수도'
def show(self):
print('국가 클래스의 메소드입니다.')
class Korea(Country):
"""Sub Class"""
def __init__(self, name):
self.name = name
def show_name(self):
print('국가 이름은 : ', self.name)
- REPL에서 한번 실행해보겠습니다.
- 상속받은 서브 클래스에서는 상속해준 슈퍼 클래스의 속성과 메소드를 모두 사용할 수 있음을 확인할 수 있습니다.
>>> from inheritance import *
>>> a = Korea('대한민국')
>>> a.show()
국가 클래스의 메소드입니다.
>>> a.show_name()
국가 이름은 : 대한민국
>>> a.capital
'수도'
>>> a.name
'대한민국'
3. 상속과 self
- 상속을 하면, 자식 클래스의 인스턴스가 자식 클래스의 self 뿐만아니라, 부모 클래스의 self에도 들어가게 됩니다.
- 아래와 같이 코드를 작성해봅니다.
class Country:
def __init__(self):
print('ParentClass self :')
print(self)
def __new__(cls):
return super().__new__(cls)
class Korea(Country):
def __init__(self):
super().__init__()
print('ChildClass self :')
print(self)
def __new__(cls):
return super().__new__(cls)
- REPL에서 한번 실행해보겠습니다.
- 부모에서도 자식에서도 self가 동일한 자식 클래스의 인스턴스를 받고 있음을 알 수 있습니다.
>>> korea = Korea()
ParentClass self :
<__main__.Korea object at 0x000002055993BFD0>
ChildClass self :
<__main__.Korea object at 0x000002055993BFD0>
4. 메소드 오버라이딩 (Method overriding)
4-1 일반적인 메소드 오버라이딩
- 메소드 오버라이딩은 부모 클래스의 메소드를 자식 클래스에서 재정의 하는 것입니다.
- 코드로 한번 보겠습니다. Korea 클래스에서 부모의 show 메소드를 재정의 합니다.
class Korea(Country):
"""Sub Class"""
def __init__(self, name,population, capital):
self.name = name
self.population = population
self.capital = capital
def show(self):
print(
"""
국가의 이름은 {} 입니다.
국가의 인구는 {} 입니다.
국가의 수도는 {} 입니다.
""".format(self.name, self.population, self.capital)
)
... 생략
- 결과를 보겠습니다.
- 부모 클래스의
show()
메소드는 무시되고 자식클래스의 show()
메소드가 수행됩니다.
>>> from inheritance import *
>>> a = Korea('대한민국', 50000000, '서울')
>>> a.show()
국가의 이름은 대한민국 입니다.
국가의 인구는 50000000 입니다.
국가의 수도는 서울 입니다.
>>>
4-2 부모 메소드 호출하기
- 부모클래스의 메소드도 수행하고, 자식클래스의 메소드의 내용도 함께 출력하기를 원할 수 있습니다.
- 그럴때는
super()
라는 키워드를 사용하면 자식클래스 내에서 코드에서도 부모클래스를 호출할 수 있습니다.
class Korea(Country):
... 생략
def show(self):
super().show()
print(
"""
국가의 이름은 {} 입니다.
국가의 인구는 {} 입니다.
국가의 수도는 {} 입니다.
""".format(self.name, self.population, self.capital)
)
... 생략
- 결과를 확인해봅니다.
- 부모클래스의 'show()' 또한 실행이 되었음을 확인할 수 있습니다.
>>> from inheritance import *
>>> a = Korea('대한민국', 50000000, '서울')
>>> a.show()
국가 클래스의 메소드입니다.
국가의 이름은 대한민국 입니다.
국가의 인구는 50000000 입니다.
국가의 수도는 서울 입니다.
>>>
5. 다중상속
- C# 또는 Java는 다중상속이 불가능한 언어입니다.
- 파이썬은 C++과 같이 다중상속이 가능합니다.
- 작성 형식은 아래와 같습니다.
```python
class 부모클래스1:
...내용...
class 부모클래스2:
...내용...
class 자식클래스(부모클래스1, 부모클래스2):
...내용...
```
- 예제 코드 입니다.
- 아래와 같이 2개의 클래스를 상속하였습니다. 상속 개수에는 제한이 없습니다.
class Country:
"""Super Class"""
...생략
class Province:
Province_list = []
class Korea(Country,Province ):
"""Sub Class"""
... 생략
기타. mro() 메소드
mro()
- 클래스를 작성하면 상속 관계를 확인할 수 있는 메소드- Korea클래스에
mro()
메소드를 실행하면 Korea클래스 다음 Country 다음 object가 나옵니다. - 모든 클래스는 object클래스의 상속입니다. 기본적으로 파이썬 3부터 object가 생략되어 코드가 작성됩니다.
>>> Korea.mro()
[<class 'inheritance.Korea'>, <class 'inheritance.Country'>, <class 'object'>]