https://wikidocs.net/16073


43. class 정리 - 상속(inheritance)

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'>]


+ Recent posts